最近在学习【MySQL事务&锁】这块知识,一不留神和MSSQL乱窜了~.~


文章最初是想查看MySQL vs MSSQL在下面环境产生的阻塞现象
会话1开启事务更新数据尚未提交->会话2读取会话1中修改的行->会话3读取会话1中修改的行
MySQL:会话1阻塞会话2,会话1阻塞会话3
MSSQL:会话1阻塞会话2,会话2阻塞会话3
MySQL同学对MSSQL的这种阻塞链表示很不理解!我们查看MSSQL中的锁等待信息,会话2和会话3等待的是同一资源,为什么sys.sysprocesses中显示会话2阻塞会话3呢?
我也不知道,也不想去深挖。还是先把MSSQL中简单SELECT/UPDATE/DELETE操作要申请的锁梳理清楚~
【Microsoft SQL Server企业级平台管理实践】的第9章和第10章详细介绍了阻塞与死锁,建议阅读原文


使用SQL Server Profiler跟踪Lock:Acquired、Lock:Released事件,查看语句执行过程中锁的申请和释放过程
使用sp_lock或者sys.dm_tran_locks罗列连接持有的锁信息
下面的分析基于REPEATABLE READ隔离级别,显式开启事务,执行SELECT/UPDATE操作,且不提交事务
一、堆表
从第一行开始,依次扫描表中的每一行数据,然后检查这一行是不是用户需要的数据,直到最后一行
1.1、SELECT
Profiler跟踪看到的过程如下:
OBJECT申请IS锁->PAGE申请IS锁->RID申请S锁->不是用户所需数据/是用户所需数据->释放当前RID上的S锁/不释放当前RID上的S锁->下一个RID...->下一个PAGE...
注意:扫描过程会对读到的每一条记录加上一个S锁(若记录不返回,在读完这条记录就释放)。只要有任何一条记录上的锁没申请到,查询就会被阻塞
加锁情况(sp_lock):表级别加IS锁;所有PAGE加IS锁;返回行加S锁
1.2、UPDATE
Profiler跟踪看到的过程如下:
OBJECT申请IX锁->PAGE申请IU锁->RID申请U锁->不是用户所需数据/是用户所需数据->释放当前RID上的U锁/PAGE升级成IX锁,RID升级成X锁->下一个RID...->下一个PAGE...
对于UPDATE语句,可简单理解先做查询,把需要修改的记录给找到,然后在这个记录上做修改。找记录的动作要加S锁,找到要修改的记录后会先加U锁,再将U锁升级成X锁
加锁情况(sp_lock):表级别加IX锁;修改行加X锁、修改行所在PAGE加IX锁;其他PAGE加IU
二、非聚集索引
这里是指执行计划使用了非聚集索引
2.1、SELECT
• 返回列在索引中
索引覆盖了请求所包含的列,不需要访问表仅需要访问索引本身
加锁情况(sp_lock):表级别加IS锁;返回行对应索引键值加S锁、返回行对应索引键值所在PAGE加IS锁
• 返回列不在索引中
使用索引键值去访问非聚集索引,然后使用书签访问非聚集索引所在表获取额外的信息
加锁情况(sp_lock):表级别加IS锁;返回行对应索引键值加S锁、返回行对应索引键值所在PAGE加IS锁;返回行加S锁、返回行所在PAGE加IS锁
2.2、UPDATE
• 更新非索引列
加锁情况(sp_lock):表级别加IX锁;修改行加X锁、修改行所在PAGE加IX锁;修改行对应索引键值加U锁、修改行对应索引键值所在PAGE加IU锁
• 更新索引列
加锁情况(sp_lock):表级别加IX锁;修改行加X锁、修改行所在PAGE加IX锁;原索引键值要删除,新索引键值要插入,对应两个KEY加X锁、索引键值所在PAGE加IX锁
三、聚集索引
3.1、SELECT
加锁情况(sp_lock):表级别加IS锁;返回行加S锁;返回行所在PAGE加IS锁
3.2、UPDATE
• 更新非索引列
加锁情况(sp_lock):表级别加IX锁;修改行加X锁;修改行所在PAGE加IX锁
• 更新索引列
加锁情况(sp_lock):表级别加IX锁;修改行原键值要删除,新键值要插入,对应两个KEY加X锁;修改行所在PAGE加IX锁

--隔离级别
SET TRANSACTION ISOLATION LEVEL REPEATABLE READ
SET TRANSACTION ISOLATION LEVEL READ COMMITTED --PAGE
DBCC IND(AdventureWorks2008R2,'Employee_Demo',-1)
DBCC IND(7,981578535,1)
DBCC TRACEON (3604)
DBCC PAGE(7,1,3792,3) WITH TABLERESULTS
--KeyHashValue
SELECT * FROM Employee_Demo WHERE %%lockres%% ='(a0c936a3c965)' --有没有阻塞发生?是什么时候发生的?在哪个数据库上?
SELECT spid,kpid,blocked,waittime,s.waitresource,dbid,s.last_batch,status FROM sys.sysprocesses s WHERE spid>50
--现在阻塞发生在哪个或哪些资源上
SELECT request_session_id
,resource_type
,request_status
,request_mode
,resource_description
,OBJECT_NAME(p.object_id) AS OBJECT_NAME
,i.name index_name
FROM sys.dm_tran_locks
LEFT JOIN sys.partitions p
ON sys.dm_tran_locks.resource_associated_entity_id = p.hobt_id
LEFT JOIN sys.indexes i
ON p.object_id = i.[object_id]
AND p.index_id = i.index_id
ORDER BY request_session_id,resource_type

MSSQL-SELECT&UPDATE动作要申请的锁的更多相关文章

  1. 从 select ... for update来分析mysql的锁

    一 mysql的悲观锁 - 以行锁做示例 每次拿数据的时候都认为别的线程会修改数据,所以每次拿数据的时候都会给数据上锁.上锁之后,当别的线程想要拿数据时,就会阻塞.直到给数据上锁的线程将事务提交或者回 ...

  2. SQL Server 的各种查询和要申请的锁

    前期准备: 1.建表 create table T_Btree(X int primary key,Y nvarchar(4000));            create table T_Heap( ...

  3. 笔记28 mssql的update :from语法

    原文:笔记28 mssql的update :from语法 笔记28 mssql的update :from语法 --mssql的update :from语法 --a表 b表 结构分别 id ,name ...

  4. mysql 通过测试'for update',深入了解行锁、表锁、索引

    mysql 通过测试'for update',深入了解行锁.表锁.索引 条件 FOR UPDATE 仅适用于InnoDB存储引擎,且必须在事务区块(BEGIN/COMMIT)中才能生效. mysql默 ...

  5. sql server update时,是行锁还是表锁

    https://bbs.csdn.net/topics/120000749 http://www.cnblogs.com/s021368/articles/2148659.html 问题: udpat ...

  6. mssql的update :from语法

    一条Update更新语句是不能更新多张表的,除非使用触发器隐含更新.而表的更新操作中,在很多情况下需要在表达式中引用要更新的表以外的数据.我们先来讨论根据其他表数据更新你要更新的表 一.MS    S ...

  7. SQL Server中DML语句要申请的锁

    对于select语句: 1.当採用表扫描时,会直接锁定page,而不是锁定详细的某条记录,所以会有这些锁: A.数据库S锁 B.表的IS锁 C.页的S锁 2.当採用索引来查找数据时,会锁定详细的记录, ...

  8. MSSQL 批量Update

    UPDATE dbo.WX_TWODIMENCODE_INFO SET wti_scan_views=t.count FROM ( SELECT COUNT(*) AS 'count',lci_ere ...

  9. [Hibernate] - Select/Update/Delete/Insert

    Java bean: package com.my.bean; import java.util.Date; public class WorkPack { private String uWorkP ...

随机推荐

  1. pyhon列表去重方法总结

    开发中对数组.列表去重是非常常见的需求,对一个list中的id进行去重,有下面几种方法,前面两种方法不能保证顺序, 后面两种方法可以保持原来的顺序. 下面的代码都在Python3下测试通过, Pyth ...

  2. 06 Zabbix分布式监控和主被动模式

    06 Zabbix分布式监控和主被动模式 zabbix proxy设置 使用zabbix代理的好处 监控拥有不可靠的远程区域 当监控项目数以万计的时候使用代理分担zabbix-proxy压力 简化分布 ...

  3. Change upload file limit in specified Webapllication in SharePoint (PowerShell)

    http://gallery.technet.microsoft.com/office/Change-upload-file-limit-89502ff2  http://sharepointrela ...

  4. IDEA安装和激活

    IDEA安装 按照最新版本有可能会有很多BUG的原则,我们就安装IDEA 2018.1.6版本的. 首先,我们到IDEA官网去下载IDEA,官网链接,但是这个界面的版本一般为最新的. 这里我放出IDE ...

  5. NinePatch图片

    绍 参考 :http://blog.sina.com.cn/s/blog_5033827f0100r4dm.html NinePatch图片以*.9.png结尾,和普通图片的区别是四周多了一个边框(如 ...

  6. Ubuntu16.04中禁用UTC解决双系统时间问题

    解决方法一 sudo hwclock -w --localtime 解决方法二 timedatectl set-local-rtc 1 解决方法三 修改/etc/adjtime文件中的UTC,为LOC ...

  7. [CF1091D]New Year and the Permutation Concatenation

    link 题目大意 给$n!$个$n$的排列,按字典序从小到大连成一条序列,例如$3$的情况为:$[1,2,3, 1,3,2, 2,1,3 ,2,3,1 ,3,1,2 ,3,2,1]$,问其中长度为$ ...

  8. P1558 色板游戏 线段树+二进制状压

    好,这个想法是我想拿去做HH的项链的.但是那个颜色有十万种...直接爆. 做这个倒是so easy 被两个地方坑了.1,a,b可能大小相反. 2,ask之前要down一波,我没down就挂了..... ...

  9. [luogu3398][仓鼠找sugar]

    luogu3398 思路: 假设松鼠a要从a1去a2,松鼠b要从b1去b2,ks表示lca(a1,a2)和lca(b1,b2)中深度较深的那个.那么,若要使得两只松鼠可能相遇,则只要满足lca(a1, ...

  10. (转)Maven之自定义archetype生成项目骨架

    背景:最近在开发一个项目的基础构件,在以后项目的开发过程中可以直接使用该构件快速的生成项目骨架进行开发. 摘要:使用过Maven的人都知道maven中有许多功能都是通过插件来提供的,今天我们来说一下其 ...