码迷,mamicode.com
首页 > 数据库 > 详细

hibernnate 使用Oracle的sequence为对象生成主键 自增50的问题

时间:2014-08-29 15:53:28      阅读:198      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   使用   io   ar   数据   

  前段时间在做一个SSH的项目,使用Oracle中的sequence作为对象表的主键生成策略,在数据库中已经配置好了sequence的步长为1,可是在运行测试时,发现主键ID每次增加的步长是50。

  奇怪之余Google一下,找到如下的解决方案,在对实体类的ID进行注解时,加上一句"allocationSize=1",例如对表EL的主键配置了一个序列叫"EL_SEQ",那么在getId方法上面使用如下注解即可解决。

@SequenceGenerator(name="seqGenerator", sequenceName="EL_SEQ",allocationSize=1)

一下纯属猜测,待后面测试

 

后来大概浏览量一下原因,很多网友说是cache的问题,猜测是在项目启动时,hibernate会一次性从数据库中取50个ID缓存在内存里,之后save对象时就从内存分配避免频繁向数据库取nextval,从而可以轻微的提高数据库性能。而测试用例每次都会重启hibernate,导致ID以50的步长增加。

附上链接
 
http://stackoverflow.com/questions/5346147/hibernate-oracle-sequence-produces-large-gap

hibernnate 使用Oracle的sequence为对象生成主键 自增50的问题

标签:style   blog   http   color   os   使用   io   ar   数据   

原文地址:http://www.cnblogs.com/xhyper/p/3945076.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!