深入分析mssql数据库中事务隔离级别和锁机制

深入分析mssql数据库中事务隔离级别和锁机制

ID:30517629

大小:18.31 KB

页数:8页

时间:2018-12-31

深入分析mssql数据库中事务隔离级别和锁机制_第1页
深入分析mssql数据库中事务隔离级别和锁机制_第2页
深入分析mssql数据库中事务隔离级别和锁机制_第3页
深入分析mssql数据库中事务隔离级别和锁机制_第4页
深入分析mssql数据库中事务隔离级别和锁机制_第5页
资源描述:

《深入分析mssql数据库中事务隔离级别和锁机制》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库

1、我真正系统地接触和学习党的基本知识是在这次中级党校的培训班上。通过学习,了解了党的发展历程,对党的性质、宗旨、任务等基本知识有了进一步的了解深入分析MSSQL数据库中事务隔离级别和锁机制  锁机制  NOLOCK和READPAST的区别。  1.开启一个事务执行插入数据的操作。  ?12345BEGINTRANtINSERTINTOCustomerSELECT'a','a'  2.执行一条查询语句。  ?1SELECT*FROMCustomerWITH(NOLOCK)  结果中显示”a”和”a”。当1中事务回滚后,那么a将成为脏数据。(注:1中的事务未提交)。NOLOCK表明没有对数据表添

2、加共享锁以阻止其它事务对数据表数据的修改。  ?1SELECT*FROMCustomer  这条语句将一直死锁,直到排他锁解除或者锁超时为止。(注:设置锁超时SETLOCK_TIMEOUT1800)  ?1SELECT*FROMCustomerWITH(READPAST)  这条语句将显示a未提交前的状态,但不锁定整个表。这个提示指明数据库引擎返回结果时忽略加锁的行或数据页。  3.执行一条插入语句。  ?BEGINTRANtINSERTINTOCustomerSELECT'b','b'COMMITTRANt对党的认识也有了进一步的提高。才真正体会到了中国共产党的伟大、光荣和正确,更感到只

3、有中国共产党是全中国最广大人民利益的忠实代表我真正系统地接触和学习党的基本知识是在这次中级党校的培训班上。通过学习,了解了党的发展历程,对党的性质、宗旨、任务等基本知识有了进一步的了解  这个时候,即使步骤1的事务回滚,那么a这条数据将丢失,而b继续插入数据库中。  NOLOCK  1.执行如下语句。  ?BEGINTRANtttSELECT*FROMCustomerWITH(NOLOCK)WAITFORdelay'00:00:20'COMMITTRANttt  注:NOLOCK不加任何锁,可以增删查改而不锁定。  ?INSERTINTOCustomerSELECT'a','b'–不锁定D

4、ELETECustomerwhereID=1–不锁定SELECT*FROMCustomer–不锁定UPDATECustomerSETTitle='aa'WHEREID=1–不锁定  ROWLOCK  1.执行一条带行锁的查询语句。  ?SETTRANSACTIONISOLATIONLEVELREPEATABLEREAD--(必须)BEGINTRANtttSELECT*FROMCustomerWITH(ROWLOCK)WHEREID=17WAITFORdelay'00:00:20'COMMITTRANttt  注:在删除和更新正在查询的数据时,会锁定数据。对其他未查询的行和增加,查询数据无影

5、响。  ?11INSERTINTOCustomerSELECT'a','b'–不等待DELETECustomerwhereID=17–等待DELETECustomerwhereID17–不等待SELECT*FROMCustomer–不等待对党的认识也有了进一步的提高。才真正体会到了中国共产党的伟大、光荣和正确,更感到只有中国共产党是全中国最广大人民利益的忠实代表我真正系统地接触和学习党的基本知识是在这次中级党校的培训班上。通过学习,了解了党的发展历程,对党的性质、宗旨、任务等基本知识有了进一步的了解UPDATECustomerSETTitle='aa'WHEREID=17–等待UPDATE

6、CustomerSETTitle='aa'WHEREID17–不等待  HOLDLOCK,TABLOCK和TABLOCKX  1.执行HOLDLOCK  ?BEGINTRANtttSELECT*FROMCustomerWITH(HOLDLOCK)WAITFORdelay'00:00:10'COMMITTRANttt  注:其他事务可以读取表,但不能更新删除  updateCustomersetTitle='aa'—要等待10秒中。  SELECT*FROMCustomer—不需要等待  2.执行TABLOCKX  ?BEGINTRANtttSELECT*FROMCustomerWITH(T

7、ABLOCKX)WAITFORdelay'00:00:10'COMMITTRANttt  注:其他事务不能读取表,更新和删除  updateCustomersetTitle='aa'—要等待10秒中。  SELECT*FROMCustomer—要等待10秒中。  3.执行TABLOCK  ?BEGINTRANtttSELECT*FROMCustomerWITH(TABLOCK)WAITFORdelay'00:00:10'

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。