SQL Server 数据修改操作全解析
1. 身份标识(Identity)与序列对象(Sequence)对比
在 SQL Server 中,身份标识和序列对象是用于生成唯一值的两种方式,它们在多个方面存在差异。
1.1 日志缓冲与性能
- 身份标识 :在日志缓冲区刷新前操作失败,恢复的身份标识值可能是较早的,但由于恢复过程会撤销插入操作,所以重用未提交插入生成的旧身份标识值不是问题。因此,SQL Server 不需要为每个与身份标识缓存相关的磁盘写入强制刷新日志缓冲区。
- 序列对象 :应用程序可以请求序列值并用于任何目的,不一定存储在数据库行中。如果 SQL Server 崩溃后应用程序请求新值,为保证不重复生成已使用过的旧值,SQL Server 会为每个与序列缓存相关的磁盘写入强制刷新日志缓冲区。
性能测试结果显示,在无缓存情况下生成 10,000,000 个值时,序列对象大约有 10,000,000 次日志刷新,而身份标识只有约 13,000 次。序列对象耗时近一小时,身份标识仅需约两分钟。
1.2 默认缓存大小
不同类型的身份标识和序列对象默认缓存大小不同,且不保证始终不变。在测试版本中,INT 类型的身份标识默认缓存大小为 1000,生成 10,000,000 个值约需一秒;序列对象默认缓存大小为 50,生成相同数量的值约需一分钟。切换功能时,需进行测试并考虑使用显式缓存大小以获得相似性能。
超级会员免费看
订阅专栏 解锁全文

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



