34、SQL Server 数据修改操作全解析

SQL Server 数据修改操作全解析

1. 身份标识(Identity)与序列(Sequence)对比

在 SQL Server 中,身份标识和序列是两种用于生成唯一值的机制,它们在多个方面存在差异。

1.1 日志刷新与性能
  • 身份标识 :在日志缓冲区刷新前操作失败时,恢复的身份标识值可能是较早的,但由于恢复过程会撤销插入操作,所以重用未提交插入生成的旧身份标识值不是问题。因此,SQL Server 不需要为每个与身份标识缓存相关的磁盘写入强制刷新日志缓冲区。
  • 序列 :应用程序可以请求序列值并用于任何目的,不一定存储在数据库行中。如果 SQL Server 崩溃,应用程序再次请求新值时,需要保证不会再次生成已使用过的旧值。为了确保这一点,SQL Server 会为每个与序列缓存相关的磁盘写入强制刷新日志缓冲区。

通过性能测试结果可以看到序列缓存大小与日志刷新次数的关联。例如,在无缓存情况下生成 10,000,000 个值时,序列大约有 10,000,000 次刷新,而身份标识只有约 13,000 次,性能差异显著,序列操作几乎需要一小时,而身份标识只需约两分钟。

另外,默认缓存大小也很重要,且不保证始终不变。在测试版本中,INT 类型的身份标识默认缓存大小为 1000,生成 10,000,000 个值约需一秒;序列对象默认缓存大小为 50,生成相同数量的值约需一分钟。在从一种功能切换到另一种功能时,要进行测试,并考虑使用足够大的显式缓存大小以获得类似的性能。

1.2 详细对比
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值