MSSql Server事务和锁研究
来源:互联网 发布:淘宝抢购怎样抢的快 编辑:程序博客网 时间:2024/06/01 11:31
锁:主要指共享锁和排他锁两种经常用到的锁。
隔离级别:设置在事务上的,共享锁的锁定时间与事务的隔离级别有关。update和delete默认都发出排他锁。
隔离级别
脏读
不可重复读取
幻像
说明
未提交读(read uncommitted)
是
是
是
如果其他事务更新,不管是否提交,立即执行
提交读(read committed默认)
否
是
是
读取提交过的数据。如果其他事务更新没提交,则等待
可重复读(repeatable read)
否
否
是
查询期间,不允许其他事务update
可串行读(serializable)
否
否
否
查询期间,不允许其他事务insert或delete
锁提示:在执行SQL语句的时候查询语句发出什么样的锁,这就由事务的隔离级别决定了。一般情况,读语句(select)发出共享锁,写语句(update,insert,delete)发出排他锁。但是,如果想改变sql语句发出的锁怎么办呢,SQLserver为我们提供了锁定提示的概念。
锁定提示对SQL语句进行特别指定,这个指定将覆盖事务的隔离级别,相当于是对默认锁状态的一个补充,可以对每条语句的锁级别进行覆盖操作。
主要类型有:
类型1
① READUNCOMMITTED:不发出锁
② READCOMMITTED:发出共享锁,保持到读取结束
③ REPEATABLEREAD:发出共享锁,保持到事务结束
④ SERIALIZABLE:发出共享锁,保持到事务结束
类型2
① NOLOCK:不发出锁。等同于READUNCOMMITTED
② HOLDLOCK:发出共享锁,保持到事务结束。等同于SERIALIZABLE
③ XLOCK:发出排他锁,保持到事务结束。
④ UPDLOCK:发出更新锁,保持到事务事务结束。(更新锁:不阻塞别的事物,允许别的事物读数据(即更新锁可与共享锁兼容),但他确保自上次读取数据后数据没有被更新)
⑤ READPAST:发出共享锁,但跳过锁定行,它不会被阻塞。适用条件:提交读的隔离级别,行级锁,select语句中。
类型3
① ROWLOCK:行级锁
② PAGLOCK:页级锁
③ TABLOCK:表锁
④ TABLOCKX:表排他锁
引用自http://www.cnblogs.com/qanholas/archive/2012/01/04/2312248.html- MSSql Server事务和锁研究
- [MSSQL]SQL Server 事务语法
- [MSSQL]SQL Server 事务语法
- mssql server 2000 触发器研究
- SQL Server事务和锁
- sql server 事务和锁
- MSSQL事务
- MSSQL之十 触发器和事务
- SQL Server 的事务和锁
- SQL Server 事务和锁详解
- SQL Server中的事务和锁
- 转SQL Server 的事务和锁
- SQL Server 的事务和锁
- 转SQL Server 的事务和锁
- SQL Server 的事务和锁
- 转SQL Server 的事务和锁
- 讲解MSSQL数据库中SQL锁机制和事务隔离级别
- 讲解MSSQL数据库中SQL锁机制和事务隔离级别
- CCFLow 学习笔记_安装
- ibatis存储过程参数
- 发给过覆盖
- ubuntu安装使用笔记02——一些配置
- myeclipse修改乱码(编码格式修改)
- MSSql Server事务和锁研究
- uIP嵌入式TCP/IP协议栈
- C++各大开源库(转)
- Windows下编译 OpenSceneGraph
- 使用百度地图申请Android API Key时keytool使用方法
- C++ 类设计的五项基本原则
- android apk互调
- js小数计算小数点后显示多位小数
- 浙大 PAT 1019. General Palindromic Number (20)