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";其他看源码吧。
特点是:需要和数据库进行一次查询才能生成。数据库全局唯一。