加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – sql中nolock的语法

发布时间:2020-12-12 16:38:25 所属栏目:MsSql教程 来源:网络整理
导读:我已经看到sql语句使用nolock和with(nolock) 例如 – select * from table1 nolock where column1 10 和 select * from table1 with(nolock) where column1 10 以上哪些陈述是正确的,为什么? 解决方法 第一个声明不会锁定任何东西,而第二个声明不会锁定.当我
我已经看到sql语句使用nolock和with(nolock)
例如 –
select * from table1 nolock where column1 > 10

select * from table1 with(nolock) where column1 > 10

以上哪些陈述是正确的,为什么?

解决方法

第一个声明不会锁定任何东西,而第二个声明不会锁定.当我刚刚在SQL Server 2005中进行测试时,
select * from table1 nolock where column1 > 10

“nolock”成为table1的查询中的别名.

select * from table1 with(nolock) where column1 > 10

执行所需的nolock功能.持怀疑态度?在一个单独的窗口中运行

BEGIN TRANSACTION
UPDATE tabl1
 set SomeColumn = 'x' + SomeColumn

锁定表,然后在自己的窗口中尝试每个锁定语句.第一个将挂起,等待锁释放,第二个将立即运行(并显示“脏数据”).不要忘记发行

ROLLBACK

当你完成了

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读