SQL Server 行版本控制

系统 1261 0

什么时候开启行版本?

当发现系统中存在大量读写阻塞的时候,就是我们开启行版本的时候了。要点:写写阻塞的场景行版本技术解决不了

开启方式:

      -- 设置为单用户

ALTER DATABASE MyTest SET SINGLE_USER WITH ROLLBACK IMMEDIATE;

GO

-- 开启行版本(事务级)

ALTER DATABASE MyTest SET ALLOW_SNAPSHOT_ISOLATION ON;

GO

-- 开启语句级行版本

ALTER DATABASE MyTest SET READ_COMMITTED_SNAPSHOT ON WITH no_wait

GO

-- 设置为多用户

ALTER DATABASE MyTest SET MULTI_USER WITH ROLLBACK IMMEDIATE;

GO


    

 开启语句级行版本注意点:

如果将 READ_COMMITTED_SNAPSHOT 设置为 ON,则数据库引擎会使用行版本控制为每个语句提供一个在事务上一致的数据快照, 缺点是用户读到的虽然不是一个脏数据,但是可能是个正在被修改马上就要过期的数据值。如果根据这个过期的值做数据修改,会产生逻辑错误。

SQL Server 行版本控制


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论