在Hibernate中实现自己的主键生成器(id Generator)

        Hibernate提供了很多内置的Generator,能很好的满足大多数的应用场景。但开发者可以选择提供自己特定的Generator实现,以满足自己的特定需求——如用更有意义的字符串类型的主键代替整型主键。我们考虑假设有一个user表,主键字段的值我更希望看到的是类似于“U1,U2,U3…”这样更有意义的主键,而不是简单的“1,2,3…”。在数据库中存在大量表,并且表之间的关系较为复杂的情况下,使用有意义的字符串类型的主键能使开发者对表之间的关系更一目了然。

        我希望该Generator具有以下功能:
        1、 生成的主键是字符串类型。
        2、 前缀英文字母或单词可以在配置文件中任意设置。
        3、 前缀后面的数字自动增加。
        为了实现上述功能,我查看了一下Hibernate所提供的内置的Generator,其中的“hilo”与我要实现的功能较为接近,只不过它返回的是long,short或int,而不是String。看来可以对它稍加改造,于是查看了它的源代码:org.hibernate.id.TableHiLoGenerator。大家可以自己看一下,我就不帖出来了。根据TableHiLoGenerator,很快就完成了我自己的MyGenerator。代码如下:

java 代码
  1. package com.mytest.hibernate.util;   
  2.   
  3. import java.util.Properties;   
  4. import java.io.Serializable;   
  5.   
  6. import org.hibernate.dialect.Dialect;   
  7. import org.hibernate.HibernateException;   
  8. import org.hibernate.engine.SessionImplementor;   
  9. import org.hibernate.id.*;   
  10. import org.hibernate.type.*;   
  11. import org.hibernate.util.PropertiesHelper;   
  12.   
  13. public class MyGenerator extends TableGenerator{   
  14.        
  15.     public static final String PREFIX = "prefix";   
  16.     private String prefix;   
  17.   
  18.     public void configure(Type type, Properties params, Dialect d) {   
  19.         super.configure(type, params, d);          
  20.         prefix=PropertiesHelper.getString(PREFIX,params,"");       
  21.     }   
  22.   
  23.     public synchronized Serializable generate(SessionImplementor session, Object obj)  throws HibernateException {   
  24.         int val = ( (Integer) super.generate(session, obj) ).intValue();   
  25.         return prefix+val;   
  26.     }   
  27. }  

        我只是增加了一个prefix,该前缀的值可以在配置文件中任意指定。下面看看怎样具体使用该Generator:
        第一步,在数据库中增加一个表key_generator,在该表中增加一个字段user_id,该字段的类型为Integer,并给该字段一个初始值1。
        第二步,写User.hbm.xml配置文件

xml 代码
  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"   
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  4. <hibernate-mapping package="com.mytest.hibernate.entity.user">  
  5.     <class name="User" table="user">  
  6.         <id name="userId" type="string" column="USER_ID_">  
  7.             <generator class="com.mytest.hibernate.util.MyGenerator">  
  8.                 <param name="table">key_generator</param>  
  9.                 <param name="column">user_id</param>  
  10.                 <param name="prefix">U</param>  
  11.             </generator>  
  12.     </id>  
  13.             …   
  14. </class>  
  15. </hibernate-mapping>  

<o:p></o:p>

         注意:MyGenerator扩展了TableGenerator类,TableGenerator类由Hibernate提供,它会根据key_generator表中的user_id字段的值来产生下一个整形值。这样我们就得到了“U1,U2,U3,…”主键。
        如果我们另外有一个department表,希望产生“D1,D2,D3,…”主健。只需在key_generator表中增加一个整型字段department_id,并给该字段一个初始值1。Department.hbm.xml如下:

xml 代码
  1. <?xml version="1.0"?>  
  2. <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"   
  3. "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
  4. <hibernate-mapping package="com.mytest.hibernate.entity.department">  
  5.     <class name="Department" table="department">  
  6.         <id name="departmentId" type="string" column="DEPARTMENT_ID_">  
  7.             <generator class="com.mytest.hibernate.util.MyGenerator">  
  8.                 <param name="table">key_generator</param>  
  9.                 <param name="column">department_id</param>  
  10.                 <param name="prefix">D</param>  
  11.             </generator>  
  12.     </id>  
  13.             …   
  14. </class>  
  15. </hibernate-mapping>  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值