Mar*_*acz 8 sql sql-server performance rowversion
我打算在我的数据库rowversion中添加大多数表来跟踪这些表中的更改.我知道添加它会影响查询的性能.
有没有人知道它是否会影响性能(慢几个百分点)或者我不应该将rowversion添加到许多表中,因为它会使DB慢得多.
仅添加rowversion/timestamp列的性能差异是您的行现在宽8个字节.
当您开始实际使用它们时,实际的性能差异就会出现.但正如我在回答类似问题时指出的那样:RowVersion和Performance
如果你不打算使用该
rowVersion字段来检查更新的项目,而是你将使用它来保持一致,以确保自上次阅读以来记录没有更新,那么这将是一个完全可以接受的用途,不会影响.如:
UPDATE MyTable SET MyField = ' @myField
WHERE Key = @key AND rowVersion = @rowVersion
Run Code Online (Sandbox Code Playgroud)
因此,只检查行以确保自上次读取应用程序以来它没有更新时的性能将是微不足道的性能差异(它必须读取行以更新它).
但是,尝试使用rowversion/timestamp列作为从上次检查以来获取所有更新项目的方法的性能将非常差.
| 归档时间: |
|
| 查看次数: |
3316 次 |
| 最近记录: |