首页 > 代码库 > hibernnate 使用Oracle的sequence为对象生成主键 自增50的问题
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
hibernnate 使用Oracle的sequence为对象生成主键 自增50的问题
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。