SQL Server IDENTITY 列增量间隙:了解缓存
SQL Server 的 IDENTITY
列,用于生成唯一的行标识符,有时会表现出意外的行为:服务器重新启动后,增量会跳跃数百,而不是依次增加一。这不是一个错误,而是 SQL Server 2012 中引入的性能优化的结果。
SQL Server 缓存标识值以提高性能。 此缓存通常存储 1,000 个 int
值或 10,000 个 bigint
/numeric
值。一旦缓存耗尽,就会分配新的批次。 但是,重新启动服务器会丢弃所有未使用的缓存值。
观察到的跳跃,最后三位数字保持不变(例如,始终以 306 结尾),反映了初始分配 1,000 后剩余的缓存值。
虽然这种缓存机制会在 IDENTITY
序列中产生间隙,但它主要提高了性能。 除非频繁重启很常见,否则影响很小。 然而,有几个选项可以缓解这个问题:
IDENTITY
列替换为 SEQUENCE
对象,以便更好地控制缓存大小。ALTER DATABASE SCOPED CONFIGURATION SET IDENTITY_CACHE = OFF;
以禁用特定数据库的缓存。重要的是要记住,即使使用这些解决方法,并发插入和事务回滚仍然会产生间隙。对于要求绝对序列连续性的应用程序,请考虑 UUID 生成器或自定义序列实现等替代方案。
以上是为什么重新启动后我的 SQL Server IDENTITY 增量会跳跃?的详细内容。更多信息请关注PHP中文网其他相关文章!