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

  前段时间在做一个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

posted on 2014-08-29 15:35  xhyper  阅读(195)  评论(0编辑  收藏  举报

导航