首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

关于Hibernate的oracle主键id生成谋略uuid、native和sequence

2012-11-09 
关于Hibernate的oracle主键id生成策略uuid、native和sequence1.uuid是产生一个32位的字符串,所以在数据库主

关于Hibernate的oracle主键id生成策略uuid、native和sequence

1.uuid是产生一个32位的字符串,所以在数据库主键字段的大小上必须要大于等于32位。另外如果之前在库表设置了触发器和sequence,那么即使是采用uuid主键生成策略,那么hibernate在做插入时,uuid将会失效,而是采用sequence中的值作为主键id。相当于先用uuid做主键id,但是在插入之前又被sequence中的值覆盖掉了。这点必须注意。删除掉该表的触发器即可恢复。

?

2.native 意味着主键生成机制的实现方式将交给hibernate决定。hibernate 将根据底层数据库适配器dialect 的定义,采用不同数据库特定的主键生成方式。(对于SQLServer和MySQL自动采用自增字段,对于oracle自动采用Sequence生成主键)

注意:在这种情形下,hibernate会默认使用名为hibernate_sequence的序列,如果oracle中没有设置,Console控制台将会产生“Hibernate: select hibernate_sequence.nextval from dualCaused by: java.sql.SQLException: ORA-02289: 序列(号)不存在”的错误。那么应当在oracle中添加名为hibernate_sequence的序列。

或者采用如下方法来指明具体使用哪个序列:

<generator type="java.lang.Long"> ??

??? <column name="USER_ID" precision="22" scale="0" />???
??? <generator class="sequence">???
??? <param name="sequence">SEQ_USER</param>???
??? </generator>???
??</id>???

热点排行