1、increment 标识符生成器
该生成器由Hibernate以递增的方式为代理主键赋值。在初始化阶段,Hibernate读取表中的最大主键值,当插入记录时,在最大值基础上递增,增量为1。如果有两个Hibernate应用进程访问同一个数据库表,可能出现同时获取相同的最大值,导致出现相同的主键值,从而有一个进程插入失败!
使用范围:
-生成标识符机制不依赖于底层数据库系统,所以他适合于所有的数据库系统。
-适用于只有单个Hibernate应用进程访问同一个数据库的场合,在集群环境下不推荐使用
-OID必须为long、int或short型,如果定义为byte类型,会抛出异常。
2、identity标识符生成器
该生成器由底层数据库来负责生成标识符,他要求底层数据库把主键定义为自动增长字段类型。
适用范围:
-由于依赖于底层数据库,所以要求底层数据系统必须支持自动增长字段类型。包括:DB2、MySQL、MsSQL、Sybase、HSQLDB、Informix等
-OID必须为long、int或short型,如果定义为byte类型,会抛出异常。
3、sequence标识符生成器
该标识符生成器利用底层数据库提供的序列来生成标识符。
<generator class="sequence">
<param name="sequence">tester_id_seq</param>
</generator>
在生成的DDL代码中会生成:
create sequence tester_id_seq;
注:MySQL不支持sequence。
当Hibernate在持久化一个SequenceTester对象时,先从底层数据库的tester_id_seq序列中获得一个唯一的序列号,再把它作为主键值。
适用范围:
-要求底层数据库必须支持序列,包括:Oracle、DB2、SAP DB、PostgreSQL等。
-OID必须为long、int或short型,如果定义为byte类型,会抛出异常。
4、hilo标识符生成器
hilo标识符生成器由HIbernate按照一种high/low算法来生成标识符,他从数据库的特定表字段中获取high值
<id name="id" type="long" column="ID">
<generator class="hilo">
<param name="table">hi_value</param>
<param name="column">next_value</param>
<param name="max_lo">100</param>
</generator>
</id>
上例:high值放在hi_value表的next_value字段中
Hibernate在持久化一个对象时,需要读取并修改hi_value表中的next_value值。这段操作在单独的事务中处理。当save时,不使用当前session对象的当前数据库联接和事务,而是在一个新的数据库连接中创建新事务,然后访问hi_value表。
适用范围:
-适用于所有的数据库系统。
-OID必须为long、int或short型,如果定义为byte类型,会抛出异常。
-只能在一个数据库中保证标识符唯一
-当用户为Hibernate自行提供数据库联接,或者Hibernate通过JTA,从应用服务器的数据源获得数据库联接时无法适用hilo,因为这样不能保证hilo在新的数据库连接的事务中访问hi_value表。在这种情况下,如果数据库系统支持序列,可以适用seqhilo生成器。对于支持序列的数据库系统,可以适用seqhilo,它从序列中获取high值。
5、native标识符生成器
该生成器依据底层数据库对自动生成标识符的支持能力,来选择适用identity、sequence或hilo标识符生成器。能自动判断底层数据库提供的生成标识符的机制。
适用范围:
-适合于跨数据库平台开发,即同一个Hibernate应用需要连接多种数据库系统的场合
-OID必须为long、int或short型,如果定义为byte类型,会抛出异常。
原文:http://blog.csdn.net/cool_rain_man/article/details/2794407