hibernate的主键生成策略包括那些

本文介绍了Hibernate的11种主键生成策略,包括uuid、guid、uuid.hex、hilo、identity、select、sequence、seqhilo、increment、foreign等。主要分为三类:无需数据库交互、一个SQL生成一个ID、一个SQL生成多个ID。讨论了各策略的优缺点,如UUID适合分布式环境,数据库序列适用于集群环境,Assigned策略允许自定义管理主键。建议根据并发需求和语义需求选择合适的策略。
摘要由CSDN通过智能技术生成
hibernate 主键生成策略有三种:序列 自增 通用
1、序列 sequence
   只能在oracle 和 DB2中使用
   <id name="id" column="id">
     <generator class="sequence">
     <param name="在数据库中创建的sequence名字"/>
     </generator>
    </id>
2、自增 identity
   智能在sqlserver 和 mysql 中使用,同时建表的时候,设置列 为 auto increment。
 <id name="id" column="id">
     <generator class="identity"/>
    </id>
3、通用 native
   mysql 就用不了了
这个oracle中必须创建一个名字为 hibernate_sequence的序列。
<id name="id" column="id">
     <generator class="native"/>
    </id>




1、uuid2,IdentifierGenerator的实现类是UUIDGenerator,具体由UUIDGenerationStrategy策略负责生成,它有两个实现StandardRandomStrategy和CustomVersionOneStrategy,他们都是使用java.util.UUID的api生成主键的,StandardRandomStrategy最终由UUID.randomUUID();生成,而CustomVersionOneStrategy则采用版本号与位运算通过构造函数newUUID(mostSignificantBits,leastSignificantBits);生成。
特点是:不需要和数据库交互,可根据RFC4122定义的5中变量控制具体的生成策略 

2、guid,IdentifierGenerator的实现类是GUIDGenerator,通过session.getFactory().getDialect().getSelectGUIDString();获得各个数据库中的标示字符串,mySql用"selectuuid()";oracle9g用return"selectrawtohex(sys_guid())fromdual";其他看源码吧。
特点是:需要和数据库进行一次查询才能生成。数据库全局唯一。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值