Hibernate创建命名策略

在开发软件时,通常要求每个开发人员遵守共同的命名策略。例如,数据库的表名以及字段名的所有字符都为大写,表名“S”结尾。对于Customer类,对应的数据库表名为CUSTOMERS。一种方法是手工设置表名和字段名,但这种方法很耗时,而且容易出错。还有一种方式是实现Hibernate的NamingStrategy接口。

 
 
 
  1. import net.sf.hibernate.cfg.NamingStrategy;  
  2. import net.sf.hibernate.util.StringHelper;  
  3.  
  4. public class MyNamingStrategy implements NamingStrategy {  
  5.     public String classToTableName(String className) {  
  6.         return StringHelper.unqualify(className).toUpperCase() + 'S';  
  7.     }  
  8.  
  9.     public String propertyToColumnName(String propertyName) {  
  10.         return propertyName.toUpperCase();  
  11.     }  
  12.  
  13.     public String tableName(String tableName) {  
  14.         return tableName;  
  15.     }  
  16.  
  17.     public String columnName(String columnName) {  
  18.         return columnName;  
  19.     }  
  20.  
  21.     public String propertyToTableName(String className, String propertyName) {  
  22.         return classToTableName(className) + '_' 
  23.                 + propertyToColumnName(propertyName);  
  24.     }  
  25. }  

为了让Hibernate采用以上命名方案,需要在Hibernate初始化阶段设置Configuration对象的NamingStrategy属性,代码如下:

 
 
 
  1. Congfiguration cnofig = new Configuration();  
  2.  
  3. config.setNameingStratefy(new MyNamingStrategy());  
  4.  
  5. SessionFactory sessionFactory = config.buildSessionFactory();  

【编辑推荐】

  1. 使用MyEclipse开发第一个Hibernate程序
  2. Hibernate的unsaved-value
  3. Hibernate中get和load方法的区别
  4. 项目添加Hibernate支持
  5. Hibernate查询语言HQL 八大要点
THE END