MS SQL SERVER 锁研究记录
首先创建一直数据表 ChenJi,有如下字段:
ID, DanWeiID, Name, ChenJi
CREATE TABLE [dbo].[ChenJi](
[ID] [int] NOT NULL,
[DanWeiID] [int] NULL,
[Name] [varchar](50) NULL,
[ChenJi] [varchar](50) NULL,
CONSTRAINT [PK_ChenJi] PRIMARY KEY CLUSTERED
(
[ID] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]
表中记录
ID DanWeiID Name ChenJi
--- ----------- --------- ---------
1 1 aa 91
2 1 bb 91
3 1 cc 33
4 2 dd 164
5 2 ee 155
6 2 ff 166
在查询分析器里面开两个连接
A连接
begin tran t1 insert into ChenJi (DanWeiID, Name, ChenJi) values (3, ‘张三', 98) rollback tran t1
插入与锁
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
insert into ChenJi (DanWeiID, Name, ChenJi) values (3, ‘李四', 99) --可以执行插入语句 select * from ChenJi --需要等待 select * from ChenJi where Name = 'aa' --需要等待 update ChenJi SET ChenJi = 91 WHERE Name = 'aa' -- 需要等待 delete from ChenJi where Name = 'aa' --需要等待
研究发现如果在一个表中进行了开启事务执行插入语句,会对这个表的select ,update,delete进行排斥锁定,但是其他连接中还可以进行insert 该表
更新与锁
在查询分析器里面开两个连接
A连接
begin tran t1 update ChenJi SET ChenJi = 91 WHERE Name = 'aa' rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
update ChenJi SET ChenJi = 91 WHERE Name = 'aa' --需要等待 select * from ChenJi where Name = 'aa' --需要等待 select * from ChenJi where Name = 'bb' --需要等待 select * from ChenJi where ChenJi =0 --需要等待 update ChenJi SET ChenJi = 91 WHERE Name = 'bb' --需要等待 delete from ChenJi where Name = 'bb' --需要等待 insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) --可以执行插入语句
研究发现如果在一个表中进行了开启事务执行更新语句,会对这个表的select ,update,delete进行排斥锁定,但是其他连接中还可以进行insert 该表
主键与锁
在查询分析器里面开两个连接
在ChenJi表上面加入主键ID int类型
A连接
begin tran t1 update ChenJi SET ChenJi = 91 WHERE ID = 1 rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
update ChenJi SET ChenJi = 91 WHERE Name = 'aa' --需要等待 select * from ChenJi where Name = 'aa' --需要等待 select * from ChenJi where ID = 1 --需要等待 --因为name = ‘aa’ select * from ChenJi where ChenJi =0 --需要等待 update ChenJi SET ChenJi = 91 WHERE Name = 'bb' --可以执行 delete from ChenJi where Name = 'bb' --可以执行 insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) --可以执行语句 update ChenJi SET ChenJi = 91 WHERE ID = 2 --可以执行 select * from ChenJi where ID = 2 --可以执行 delete from ChenJi where ID = 2 --可以执行
研究发现如果在一个表中进行了开启事务执行更新语句并用了主键做条件,会对这个表的主键对应的记录select ,update,delete进行排斥锁定,是其他连接中还可以进行insert 该表,其他的记录还可以正常的操作
索引锁
在查询分析器里面开两个连接
在ChenJi表上面对Name字段进行索引<不是唯一性的索引>, ID依旧是主键
A连接
begin tran t1 update ChenJi SET ChenJi = 91 WHERE name = ‘aa’ rollback tran t1
先开始A连接的事务,不急着结束事务
然后在B连接中 依次执行如下一些语句
update ChenJi SET ChenJi = 91 WHERE Name = 'aa' --需要等待 select * from ChenJi where Name = 'aa' --需要等待 select * from ChenJi where Name = 'bb' --可以执行 select * from ChenJi where ChenJi =0 --需要等待 update ChenJi SET ChenJi = 91 WHERE Name = 'bb' --可以执行 delete from ChenJi where Name = 'bb' --可以执行 insert into ChenJi (ID, DanWeiID, Name, ChenJi) values (100, 3, 'ymf', 98) --可以执行语句 update ChenJi SET ChenJi = 91 WHERE ID = 2 --可以执行 select * from ChenJi where ID = 2 --可以执行 delete from ChenJi where ID = 2 --可以执行
研究发现如果在一个表中进行了开启事务执行更新语句并用了索引字段做条件,会对这个表的条件对应的记录select ,update,delete进行排斥锁定,是其他连接中还可以进行insert 该表,其他的记录还可以正常的操作
MS SQL SERVER 锁研究记录的更多相关文章
- MS SQL SERVER 中的系统表
MS SQL SERVER 中的系统表 序号 名称 说明 备注 1 syscolumns 每个表和视图中的每列在表中占一行,存储过程中的每个参数在表中也占一行. 2 syscomments 包含每 ...
- (火炬)MS SQL Server数据库案例教程
(火炬)MS SQL Server数据库案例教程 创建数据库: CREATE DATABASE TDB //数据库名称 ON ( NAME=TDB_dat,//逻辑文件名 在创建数据库完成之后语句中引 ...
- Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码)
Linux下使用FreeTDS访问MS SQL Server 2005数据库(包含C测试源码) http://blog.csdn.net/helonsy/article/details/7207497 ...
- 在易语言中调用MS SQL SERVER数据库存储过程方法总结
Microsoft SQL SERVER 数据库存储过程,根据其输入输出数据,笼统的可以分为以下几种情况或其组合:无输入,有一个或多个输入参数,无输出,直接返回(return)一个值,通过output ...
- [转]了解SQL Server锁争用:NOLOCK 和 ROWLOCK 的秘密_Mr_Indigo的空间
了解SQL Server锁争用:NOLOCK 和 ROWLOCK 的秘密 关系型数据库,如SQL Server,使用锁来避免多用户修改数据时的并发冲突.当一组数据被某个用户锁定时,除非第一个用户结束修 ...
- ms sql server 在abator生成的 insert 无法获取插入 id 的原因
<insert id="abatorgenerated_insert" parameterClass="net.xxxxxl.dataobject.Users&qu ...
- MS SQL Server时间常用函数
SQLServer时间日期函数详解,SQLServer,时间日期, 1. 当前系统日期.时间 select getdate() 2. dateadd 在向指定日期加上一段时间的基础 ...
- 了解SQL Server锁争用:NOLOCK 和 ROWLOCK 的秘密
关系型数据库,如SQL Server,使用锁来避免多用户修改数据时的并发冲突.当一组数据被某个用户锁定时,除非第一个用户结束修改并释放锁,否则其他用户就无法修改该组数据. 有些数据库,包括SQL Se ...
- Oracle\MS SQL Server Update多表关联更新
原文:Oracle\MS SQL Server Update多表关联更新 一条Update更新语句是不能更新多张表的,除非使用触发器隐含更新.而表的更新操作中,在很多情况下需要在表达式中引用要更新的表 ...
随机推荐
- github中non-fast-forward错误的解决
参考文献 1.http://www.linuxidc.com/Linux/2012-04/58985.htm 2.http://ihower.tw/blog/archives/2620 3.http: ...
- Memcache技术分享:介绍、使用、存储、算法、优化、命中率
1.memcached 介绍 1.1 memcached 是什么? memcached 是以LiveJournal旗下Danga Interactive 公司的Brad Fitzpatric 为首开发 ...
- Delphi指针及其它(转)
一.指针:指向一个内存地址的变量或参数. 二.定义指针的方式如下: P: Pointer; //定义了可以指向任何类型的指针,Pointer 为无类型指针: Q, R: ^TType; //定义了指向 ...
- linux shell send and receive emails
http://www.netcan666.com/2016/02/20/%E5%88%A9%E7%94%A8telnet%E5%9C%A8%E5%91%BD%E4%BB%A4%E8%A1%8C%E5% ...
- 《linux内核设计与实现》读书笔记第一、二章
第一章 Linux内核简介 1.1 Unix的历史 1971年,Unix被移植到PDP-11型机中. 1973年,Unix操作系统用C语言改写——为Unix系统的广泛移植铺平了道路. 1977年,伯克 ...
- HBase的安装部署以及简单使用
一:下载安装 1.下载安装 2.开启hadoop与zookeeper 3.修改配置文件hbase-env export JAVA_HOME=/opt/modules/jdk1.7.0_67 expor ...
- 阅读javaScript 的原型笔记
下面我们先看一个例子已经一张图. function Foo() { } Object.prototype.name = 'My Object'; Foo.prototype.name = 'Bar'; ...
- 转:Asp.net Mvc4默认权限详细(上)
前言 上篇的菜鸟去重复之Sql的问题还没有得到满意的答案.如果哪位大哥有相关的资料解释,能够分享给我,那就太谢谢了. 以后每发表一篇博文我都会将以前遗留的问题在前言里指出,直到解决为止. 本文主要在于 ...
- shell 使用for循环 启动后台任务
为了统计多天的数据并按照天为文件名输出,写了脚本,脚本可以统计单天的数据.为了实现多天的同时进行采用 启动多个进程后台执行形式: 但是直接 执行的参数后面加上& 并不能解决,采用 echo & ...
- HTML5新特性总结
一.HTML5 中的一些有趣的新特性: 用于绘画的 canvas 元素 用于媒介回放的 video 和 audio 元素 对本地离线存储的更好的支持 新的特殊内容元素,比如 article.foote ...