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

转载于:https://www.cnblogs.com/xhyper/p/3945076.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值