Hibernate主键生成策略

===native,常用

由Hibernate根据所使用的数据库支持能力从identity、sequence或者hilo生成策略中选择一种。

<id name="userId" column="userId" type="java.lang.Integer">
	<generator class="native">
		<param name="sequence">seq_oid</param>
	</generator>
</id> 

使用这种生成策略可以根据不同的数据库采用不同的生成策略,如Oracle中使用sequence,在MySQL中使用identity,便于Hibernate应用

在不同的数据库之间移植。



===assigned,常用,默认

assigned生成策略由程序自定义主键数值,即在调用Session对象的save()方法持久化对象时,需要首先为持久化对象的标识符属性赋值。
如果<generator>元素没有设置主键生成策略,则默认为assigned生成策略。
<id name="userId" column="userId" type="java.lang.Integer">
  <generator class="assigned"></generator>
</id>



===uuid

uuid生成策略采用UUID算法来生成一个字符串类型的主键值,这个算法使用IP地址、JVM的启动时间(精确到1/4秒)、系统时间和一个

计数器值(在当前的JVM中唯一)经过计算来产生标识符属性值,可以用于分布式的Hibernate应用中。产生的标识符属性是一个32位长度

的字符串。使用这种生成策略,对应持久化类中标识符属性的类型应设置为String类型。

<id name="userId" column="userId" type="java.lang.String"> 	
  <generator class="uuid"></generator>
</id>

这种生成策略生成的数值可以保证多个数据库之间的唯一性,由于该值是32位长的字符串,所以占用的数据库空间较大。



===identity,SQL Server、MySql常用

在MS SQL Server、MySQL和DB2等数据库中可以设置表中某一字段的数值自动增长,identity生成策略通过这种方式为当前记录获取主键值。

该生成策略生成的标识符属性的类型可以是long、short、int及其封装类类型。

<id name="userId" column="userId" type="java.lang.Integer"> 	
  <generator class="identity"></generator>
</id> 



===sequence,Oracle中常用

在Oracle、DB2和PostgreSQL等数据库中创建一个序列(sequence),然后Hibernate通过该序列为当前记录获取主键值。用其生成的标识符

属性的类型可以是long、short、int及其封装类类型。

使用这种标识符属性生成策略的示例配置信息如下:
<id name="userId" column="userId" type="java.lang.Integer">
	<generator class="sequence">
		<param name="sequence">seq_oid</param>
	</generator>
</id>

param指定Hibernate使用的序列名,该行为可选。如果未指定序列名,则Hibernate默认使用名为"hibernate_sequence"的序列。



===increment,Hibernate本身维护

插入一条新记录时,首先从数据库表中获取当前主键字段的最大值,然后在最大值上加1。用其生成的ID标识符属性的类型可以是long、short、int

及其封装类类型。这种主键生成策略适合单服务器的Hibernate应用,同时数据库也只被该Hibernate应用所独享;否则不能保证生成的标识符属性

值的唯一性,即这种标识符属性生成策略并不适合非独享数据库或者分布式的Hibernate应用。

<id name="userId" column="userId" type="java.lang.Integer">
	<generator class="increment"></generator>
</id>


guid
这种生成策略借助MS SQL Server或者MySQL数据库中的GUID字符串产生标识符属性值,36位字符串。


hilo
hilo生成策略采用一种称为"高/低位"(hi/lo)的高效算法产生标识符属性值,所产生的标识符属性值为long、short、int及其封装类类型。


seqhilo
seqhilo生成策略也使用高/低位算法,产生的标识符属性值为long、short、int及其封装类类型。与hilo生成策略不同的是,它使用指定的sequence获取高位值。


foreign
foreign生成策略通过关联的持久化对象为当前持久化对象设置标识符属性值。



===如何选择生成策略

在选择Hibernate生成策略时,要具体问题具体分析。如果应用系统不需要分布式部署,在数据库支持的情况下使用native、identity、

sequence生成策略都是不错选择。如果应用需要使用多个数据库或者进行分布式的部署,则uuid生成策略是最佳的选择。如果使用

Hibernate改造遗留系统,可能需要人工采用一定的规则为标识符属性赋值,这时使用assigned生成策略比较合适。





  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值