欢迎来到天天文库
浏览记录
ID:30517629
大小:18.31 KB
页数:8页
时间:2018-12-31
《深入分析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'
此文档下载收益归作者所有