ImprovedNamingStrategy使用方法

本文详细介绍了PropertyName类的功能,用于实现Hibernate生成表命名规则策略。包括类的定义、功能描述、创建人、创建日期、开发环境等信息。
package msw;
import org.hibernate.cfg.ImprovedNamingStrategy;

/* 
 * 文件名: PropertyName.java
 * 包路径: 
 * 创建描述  
 *        创建人:马素文 
 *        创建日期:2011-7-13 上午10:49:05
 *        内容描述:
 * 修改描述  
 *        修改人:马素文 
 *        修改日期:2011-7-13 上午10:49:05 
 *        修改内容:
 * 版本: V1.0   
 */

/**
 * 类:  <code> PropertyName </code>
 * 功能描述: 实现Hibernate生成表命名规则策略
 * 创建人: 马素文
 * 创建日期: 2011-7-13 上午10:49:05
 * 开发环境: JDK6.0
 */
public class PropertyName extends ImprovedNamingStrategy
{
	private String tablePrefix = "nademo_";
	private String columnPrefix = "";
	private boolean toUpperCase = false;
	/* (non-Javadoc)
	 * @see org.hibernate.cfg.ImprovedNamingStrategy#propertyToColumnName(java.lang.String)
	 * @param propertyName
	 * @return
	 *
	 */
	@Override
	public String propertyToColumnName(String propertyName)
	{
		// TODO Auto-generated method stub
		//return super.propertyToColumnName(propertyName);
		if (toUpperCase)
		{
			return (this.columnPrefix + super.propertyToColumnName(propertyName)).toUpperCase();
		}
		else
		{
			return (this.columnPrefix + super.propertyToColumnName(propertyName));
		}
	}
	/* (non-Javadoc)
	 * @see org.hibernate.cfg.ImprovedNamingStrategy#classToTableName(java.lang.String)
	 * @param className
	 * @return
	 *
	 */
	@Override
	public String classToTableName(String className)
	{
		// TODO Auto-generated method stub
		//return super.classToTableName(className);
		if (toUpperCase)
		{System.out.println("toUpperCase");
			return (this.tablePrefix + super.classToTableName(className)).toUpperCase();
		}
		else
		{
			return (this.tablePrefix + super.classToTableName(className));
		}
	}

}//子类重写父类中的方法即可

package msw;
import org.junit.Test;

import tpcframework.core.test.base.SpringTestCase;

/* 
 * 文件名: PropertyNameTest.java
 * 包路径: 
 * 创建描述  
 *        创建人:马素文 
 *        创建日期:2011-7-13 上午10:43:06
 *        内容描述:
 * 修改描述  
 *        修改人:马素文 
 *        修改日期:2011-7-13 上午10:43:06 
 *        修改内容:
 * 版本: V1.0   
 */

/**
 * 类:  <code> PropertyNameTest </code>
 * 功能描述: 
 * 创建人: 马素文
 * 创建日期: 2011-7-13 上午10:43:06
 * 开发环境: JDK6.0
 */
public class PropertyNameTest extends SpringTestCase
{

 @Test
  public void p_name()
 {
	 PropertyName propertyName = new PropertyName();
	 String p_nam =propertyName.propertyToColumnName("loginName");
	 System.out.println("property_name is:"+p_nam);
 }
 
 @Test
 public void c_name()
 {
	 PropertyName propertyName = new PropertyName();
	 String p_nam =propertyName.classToTableName("Person");
	 System.out.println("column_name is:"+p_nam);
	 
 }
}




Spring Boot 后端搭建及与数据库交互可按以下步骤实现: ### 项目搭建 在搭建 Spring Boot 项目时,可借助 Spring Initializr 或者在 IDE 中创建 Spring Boot 项目。创建一个简单的用户管理系统,示例代码如下,定义了用户实体类: ```java package com.springboot.bean; import javax.persistence.Entity; import javax.persistence.Table; @Entity @Table(name = "user") public class User extends BaseBean { private String name; private int age; private String info; public String getName() { return name; } public void setName(String name) { this.name = name; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getInfo() { return info; } public void setInfo(String info) { this.info = info; } } ``` 此代码定义了一个名为 `User` 的实体类,对应数据库中的 `user` 表,包含 `name`、`age` 和 `info` 字段 [^2]。 ### 配置数据库连接 配置数据库连接信息,可在 `application.properties` 或 `application.yml` 文件中进行配置。 #### application.properties 配置示例 ```properties server.port=8443 spring.datasource.url=jdbc:mysql://127.0.0.1:3306/white_jotter?characterEncoding=UTF-8 spring.datasource.username=root spring.datasource.password=123456 spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.jpa.hibernate.ddl-auto = none spring.jpa.database = MYSQL spring.jpa.database-platform=org.hibernate.dialect.MySQLDialect spring.jpa.hibernate.naming-strategy = org.hibernate.cfg.ImprovedNamingStrategy spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQL5Dialect ``` 这里需注意端口、数据库名、用户名、密码要与实际使用的数据库一致 [^4]。 #### application.yml 配置示例 ```yaml server: port: 80 session-timeout: 30 tomcat.max-threads: 0 tomcat.uri-encoding: UTF-8 spring: thymeleaf: prefix: classpath:/templates/ suffix: .html mode: HTML5 encoding: UTF-8 content-type: text/html cache: false datasource: url: jdbc:mysql://localhost:3306/boot driver-class-name: com.mysql.jdbc.Driver username: password: initial-size: 10 max-active: 20 max-idle: 8 min-idle: 8 type: com.alibaba.druid.pool.DruidDataSource mybatis: mapperLocations: classpath:mapper/*.xml typeAliasesPackage: com.springboot.bean ``` 该配置文件配置了服务器、Thymeleaf 模板引擎、数据源等信息 [^5]。 ### 后端与数据库交互 在 Spring Boot 中,可使用 Spring Data JPA 或 MyBatis 等框架实现与数据库的交互。以 Spring Data JPA 为例,创建一个 `UserRepository` 接口: ```java import org.springframework.data.jpa.repository.JpaRepository; import com.springboot.bean.User; public interface UserRepository extends JpaRepository<User, Long> { // 可在此添加自定义查询方法 } ``` 此接口继承自 `JpaRepository`,可使用其提供的基本 CRUD 方法,也可自定义查询方法 [^1]。 ### 端口及其他配置 可在配置文件中设置端口等信息,示例如下: ```yaml server: port: 9999 spring: datasource: username: root password: 1234 url: jdbc:mysql:///xdb redis: port: 6379 host: localhost logging: level: com.ums: debug ``` 这里设置了服务器端口为 9999,配置了数据库和 Redis 的连接信息,以及日志级别 [^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值