• WITH (NOLOCK)


    一、介绍

    with(nolock)的主要作用是允许SELECT语句读取正在修改中的数据,也就是通常说的脏读(dirty read),对于数据修改数量很小而且对SELECT语句读出的数据精确性影响可以忽略的应用程序,可以使用这种方式来避免数据修改活动阻塞SELECT语句。
    对于隔离级别来说,它允许SELECT语句读取数据而不需要请求(S)锁,既然不请求(S)锁,所以它既不会被(X)锁阻塞也不会阻塞(X)锁。

    当同一时间有多个用户访问同一资源,并发用户中如果有用户对资源做了修改,此时就会对其它用户产生某些不利的影响,例如:

    1、脏读

    一个用户对一个资源做了修改,此时另外一个用户正好读取了这条被修改的记录,然后,第一个用户放弃修改,数据回到修改之前,这两个不同的结果就是脏读。

    2、不可重复读

    一个用户的一个操作是一个事务,这个事务分两次读取同一条记录,如果第一次读取后,有另外用户修改了这个数据,然后第二次读取的数据正好是其它用户修改的数据,这样造成两次读取的记录不同,如果事务中锁定这条记录就可以避免。

    3、幻读

    指用户读取一批记录的情况,用户两次查询同一条件的一批记录,第一次查询后,有其它用户对这批数据做了修改,方法可能是修改,删除,新增,第二次查询时,会发现第一次查询的记录条目有的不在第二次查询结果中,或者是第二次查询的条目不在第一次查询的内容中。

    NOLOCK 语句执行时不发出共享锁,允许脏读 ,等于 READ UNCOMMITTED事务隔离级别 。nolock确实在查询时能提高速度,但它并不是没有缺点的,起码它会引起脏读、只适用与select查询语句。 在一些不需要考虑脏读的场合会用到,例如当用户在论坛发广告贴时删除其所有发帖,这个查询就不怕脏读,全删,或者漏一个正在发的都不是问题。

    二、实例

     
    SQL 代码   复制
    SELECT  COUNT(UserID)   
    
    FROM    EMPLOYEE WITH (NOLOCK)           
    
    JOIN WORKING_GROUP WITH (NOLOCK)           
    
    ON EMPLOYEE.UserID = WORKING_GROUP.UserID  
    

    三、with(nolock)的使用场景

    1:数据量特别大的表,牺牲数据安全性来提升性能是可以考虑的;

    2:允许出现脏读现象的业务逻辑,反之一些数据完整性要求比较严格的场景就不合适了,像金融方面等。

    3:数据不经常修改的表,这样会省于锁定表的时间来大大加快查询速度。

    4、当使用NoLock时,它允许阅读那些已经修改但是还没有交易完成的数据。因此如果有需要考虑transaction事务数据的实时完整性时,使用WITH (NOLOCK)就要好好考虑一下。  

    四、nolock和with(nolock)的几个小区别

    1、SQL05中的同义词,只支持with(nolock);

    2、with(nolock)的写法非常容易再指定索引。

    3、跨服务器查询语句时 不能用with (nolock) 只能用nolock,同一个服务器查询时 则with(nolock)和nolock都可以用

  • 相关阅读:
    Design and Analysis of Algorithms_Decrease-and-Conquer
    TCPL 札记
    谬论:64 = 65?
    二叉树内部顶点与外部顶点在数量上的关系
    Design and Analysis of Algorithms_Divide-and-Conquer
    LeetCode 36. Valid Sudoku
    LeetCode 58. Length of Last Word
    LeetCode 66. Plus One
    LeetCode 67. Add Binary
    LeetCode 70. Climbing Stairs
  • 原文地址:https://www.cnblogs.com/riddly/p/4212538.html
Copyright © 2020-2023  润新知