前段时间在做一个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
时间: 2024-10-31 02:00:52