• 表级锁的使用


    13.4.3  表级锁的使用

    在SQL Server 2008中,用户对数据库中的数据表加锁后,其他用户不可以对数据表进行操作,直到该用户对数据表进行解锁操作后,其他用户才可以进行操作。

    通过使用表级锁可以实现对数据表的锁定操作。常见的表级锁提示如下所示。

    HOLDLOCK:该语句表示持有共享锁,直到整个事务完成。

    ROWLOCK:该语句表示强制使用表锁、盘区锁和行锁代替页锁等。

    NOLOCK:该语句执行时允许读"脏数据",但不发出共享锁。

    PAGLOCK:该语句表示在使用一个表锁的地方使用多个页锁。

    READPAST:使用该语句可以跳过任何锁定执行事务。

    TABLOAKX:使用该语句可以强制使用独占表级锁。

    UPDLOCK:该语句表示在事务结束之前,强制在读表时使用更新锁而不用共享锁。

    下面通过实例讲解表级锁的使用方法。

    【实例13-7】在"商品库存"数据表中使用HOLDLOCK表级锁。在SQL Server Management Studio中新建一个查询窗口,在该查询窗口中输入如代码13.7所示的代码;再次新建一个查询窗口,在窗口中输入如代码13.8所示的代码。

    代码13.7

    1. 01  BEGIN TRANSACTION  
    2. 02    DECLARE @dt_time varchar(8)    
    3. 03    /* 对表实行HOLDLOCK表级锁,即共享锁*/  
    4. 04    SELECT * FROM 商品库存 WITH (HOLDLOCK)   
    5. 05    /* 显示加锁时间*/  
    6. 06    SELECT @dt_time=CONVERT(VARCHAR,GETDATE(),8)  
    7. 07    PRINT '用户U1锁定时间为:' + @dt_time  
    8. 08    /* 等待秒*/  
    9. 09    WAITFOR DELAY '00:00:15'  
    10. 10    /* 显示解锁时间*/  
    11. 11    SELECT @dt_time=CONVERT(VARCHAR,GETDATE(),8)  
    12. 12    PRINT '用户U1解锁时间为:' + @dt_time  
    13. 13    COMMIT TRANSACTION /* 提交事务,解除锁定*/  
    14. 代码13.8  
    15. 14  BEGIN TRANSACTION  
    16. 15    DECLARE @dt_time varchar(8)    
    17. 16    SELECT @dt_time=CONVERT(VARCHAR,GETDATE(),8)  
    18. 17    PRINT '用户U2开始事务的时间为:' + @dt_time  
    19. 18    SELECT * FROM 商品库存   
    20. 19    SELECT @dt_time=CONVERT(VARCHAR,GETDATE(),8)  
    21. 20    PRINT '用户U2执行查询的时间为:' + @dt_time  
    22. 21    DELETE 商品库存 FROM 商品库存   
    23. 22    WHERE 名称='大米'  
    24. 23    SELECT @dt_time=CONVERT(VARCHAR,GETDATE(),8)  
    25. 24    PRINT '用户U2删除数据的时间为:' + @dt_time  
    26. 25    ROLLBACK /* 回滚事务*/ 

    【执行代码】首先执行代码13.7,接着执行代码13.8。当执行代码13.7时,"商品信息"数据表在被锁定15秒之后解锁。在15秒之内,如果执行代码13.8,则可以用SELECT语句执行查询操作,但不可以执行DELETE语句删除数据,必须等待解锁后才能执行DELETE语句。代码13.7的执行结果如图13.4所示,代码13.8的执行结果如图13.5所示。

     
    图13.4  代码13.7的执行结果
     
    图13.5  代码13.8的执行结果

    【深入学习】关于上述代码的分析如下所示:

    第1~4行启动一个事务,实现在"商品库存"数据表中使用HOLDLOCK表级锁的操作。

    第6~7行显示数据表被锁定的时间。

    第9~13行在等待15秒之后解除对数据表的锁定,然后提交事务。

    第14~18行启动一个事务,查询数据表中的数据信息,并记录查询数据的时间。

    第19~24行执行删除数据表中数据信息的操作,并记录删除数据的时间。

    第25行执行回滚事务的操作。

    说明:若想实现本实例,应首先创建两个不同的查询窗口,然后将代码13.7和代码13.8输入到不同的查询窗口中分别执行,并且两个查询窗口中程序代码的执行间隔不能超过15秒。

  • 相关阅读:
    es6中promise的实现及原理
    移动端
    javascript知识点复习
    html和css基本常识总结
    kafka,查看指定group下topic的堆积数量
    解决问题:Android设备运行自动化脚本报错 ioerror RPC server not started
    linux下安装python3
    使用vsftpd搭建FTP服务
    前端性能监控平台showslow+Yslow搭建
    学习笔记-- Python网络编程
  • 原文地址:https://www.cnblogs.com/binfire/p/1689637.html
Copyright © 2020-2023  润新知