最近在项目中遇到一个问题,因为用的是ORACLE数据库,所以有一些表是建立了序列和触发器来使添加进去的数据ID自动增加1.因为有一个操作是同时保存几个表的数据,所以就要用到先插入数据的id存到另一个表中。
奇怪的现象发生了:返回的ID,和数据库中的ID不对应,都是相差1.例如hibernate返回的是259,数据库中就是260.经过排查发现是trigger触发器的问题,因为hibernate中的model层ID映射的是序列名称,所以保存的时候hibernate先自增了一,然后到数据库中,又调用trigger,所以数据库中ID自增就为2了,自增了两次。
当然还有一些疑问,不过现在的解决方案是把数据库中的trigger删除掉了就解决了。ID就会对应了

在使用Oracle数据库和Hibernate框架的项目中,遇到了ID自增冲突的问题。具体表现为Hibernate返回的ID与数据库实际存储的ID相差1。经排查发现是由Hibernate和数据库触发器双重自增导致。最终通过移除数据库触发器解决了该问题。
175

被折叠的 条评论
为什么被折叠?



