Geo*_*pty 8 java mysql hibernate transactions auto-increment
我今天遇到了一些奇怪的行为,并想知道它是否是预期的或标准的.我们正在使用Hibernate来对抗MySQL5.在编码过程中,我忘了关闭交易,我认为其他人可以联系.
当我最终关闭事务时,运行代码并检查表,我注意到以下内容.我一直错误地运行我的代码而没有关闭事务,因此没有导致插入实际行,但是增加了自动增量代理主键值,因此我有一个间隙(即没有id字段值为751至762).
这是预期的还是标准的行为?它可能因数据库而异吗?和/或Hibernate自己的事务抽象是否会对此产生一些可能的影响?
是的,这是预期的.
如果你考虑一下:数据库还能做什么?如果您增加列,然后将其用作同一事务中其他插入的外键,并且当您正在执行其他人提交时,则他们无法使用您的值.你会得到一个差距.
像Oracle这样的数据库中的序列工作方式大致相同.一旦请求了特定值,它是否随后被提交无关紧要.它永远不会被重用.并且序列也不是绝对有序的.
| 归档时间: |
|
| 查看次数: |
2105 次 |
| 最近记录: |