对数据库稍有了解的人,数据库使用排他锁X锁来避免两个事务同时修改同一条数据,同时使用较低级别如行上加锁来提高并发度。

以下了两种场景很容易理解:

1>事务1执行 UPDATE TB1 SET C2=1 WHERE C1=1(此处假设C1为主键,使用行锁),事务1未提交,而后事务2执行UPDATE TB1 SET C2=2 WHERE C1=1,事务2必须等到事务1提交或回滚后,才能获得对该行数据的X锁;

2>事务1执行 UPDATE TB1 SET C2=1 WHERE C1=1(此处假设C1为主键,使用行锁),事务1未提交,而后事务2执行UPDATE TB1 SET C2=2 WHERE C1=2,由于事务1和2修改的数据行不同,因此事务1和事务2不会阻塞;

但对于以下两种场景就有些难理解:

1>事务1执行 UPDATE TB1 SET C1=11 WHERE C1=1(此处假设C1为主键,使用行锁),事务1未提交,而后事务2执行UPDATE TB1 SET C2=2 WHERE C1=11,数据行在事务1更新前不满足事务2的更新条件,但数据行在事务1更新后又满足事务2的更新条件,事务2会被事务1阻塞么?

测试结果:会被阻塞

测试代码:

  1. DROP TABLE dbo.TB1
  2. GO
  3. CREATE TABLE TB1
  4. (
  5. C1 INT,
  6. C2 INT
  7. )
  8. GO
  9. CREATE UNIQUE CLUSTERED INDEX IDX_C1
  10. ON dbo.TB1
  11. (
  12. C1
  13. )
  14. GO
  15. INSERT INTO dbo.TB1( C1, C2 )
  16. SELECT 1,1
  17. UNION
  18. SELECT 2,2
  19. UNION
  20. SELECT 3,3
  21. UNION
  22. SELECT 4,4
  23. GO
  24.  
  25. 事务1开始执行,修改数据行但未提交;
  26. BEGIN TRAN
  27. UPDATE dbo.TB1
  28. SET C1=11
  29. WHERE C1=1
  30.  
  31. 在新会话中事务2执行
  32. UPDATE TB1
  33. SET C2=2
  34. WHERE C1=11

2>事务1执行 UPDATE TB1 SET C1=11 WHERE C1=1(此处假设C1为主键,使用行锁),事务1未提交,而后事务2执行UPDATE TB1 SET C2=2 WHERE C1=1,数据行在事务1更新前满足事务2的更新条件,但数据行在事务1更新后又不满足事务2的更新条件,事务2会被事务1阻塞么?

测试结果:会被阻塞

测试代码:

  1. DROP TABLE dbo.TB1
  2. GO
  3. CREATE TABLE TB1
  4. (
  5. C1 INT,
  6. C2 INT
  7. )
  8. GO
  9. CREATE UNIQUE CLUSTERED INDEX IDX_C1
  10. ON dbo.TB1
  11. (
  12. C1
  13. )
  14. GO
  15. INSERT INTO dbo.TB1( C1, C2 )
  16. SELECT 1,1
  17. UNION
  18. SELECT 2,2
  19. UNION
  20. SELECT 3,3
  21. UNION
  22. SELECT 4,4
  23. GO
  24.  
  25. 事务1开始执行,修改数据行但未提交;
  26. BEGIN TRAN
  27. UPDATE dbo.TB1
  28. SET C1=11
  29. WHERE C1=1
  30.  
  31. 在新会话中事务2执行
  32. UPDATE TB1
  33. SET C2=2
  34. WHERE C1=1

3>事务1执行 INSERT INTO dbo.TB1( C1, C2 )SELECT 5,5(此处假设C1为主键,使用行锁),事务1未提交,而后事务2执行UPDATE TB1 SET C2=2 WHERE C1=5,数据行在事务1更新前满足事务2的更新条件,但数据行在事务1更新后又不满足事务2的更新条件,事务2会被事务1阻塞么?

测试结果:会被阻塞

测试代码:

  1. DROP TABLE dbo.TB1
  2. GO
  3. CREATE TABLE TB1
  4. (
  5. C1 INT,
  6. C2 INT
  7. )
  8. GO
  9. CREATE UNIQUE CLUSTERED INDEX IDX_C1
  10. ON dbo.TB1
  11. (
  12. C1
  13. )
  14. GO
  15. INSERT INTO dbo.TB1( C1, C2 )
  16. SELECT 1,1
  17. UNION
  18. SELECT 2,2
  19. UNION
  20. SELECT 3,3
  21. UNION
  22. SELECT 4,4
  23. GO
  24.  
  25. 事务1开始执行,修改数据行但未提交;
  26. BEGIN TRAN
  27. INSERT INTO dbo.TB1( C1, C2 )
  28. SELECT 5,5
  29.  
  30. 在新会话中事务2执行
  31. UPDATE TB1
  32. SET C2=2
  33. WHERE C1=5

测试结论:

对于未提交事务A修改的数据,无论该数据在更新修改的值前还是修改后的值满足事务B的修改条件,那么都会对事务B造成阻塞。

--==========================================================

年关近了,日子不好过,随时担心被母亲大人电话轰炸,压力山大,so,小伙伴们就将就着看着没啥营养的博客吧!

--==========================================================

依旧是妹子

曲苑杂坛--DML操作中如何处理那些未提交的数据的更多相关文章

  1. 曲苑杂坛--查看CPU配置

    ​--===================================================--查看CPU配置SELECT cpu_count AS [Logical CPU Coun ...

  2. 曲演杂坛--一条DELETE引发的思考

    原文:曲演杂坛--一条DELETE引发的思考 场景介绍: 我们有一张表,专门用来生成自增ID供业务使用,表结构如下: CREATE TABLE TB001 ( ID ,) PRIMARY KEY, D ...

  3. 曲演杂坛--使用TRY CATCH应该注意的一个小细节

    群里一个朋友遇到一个TRY CATCH的小问题,测试后发现是自己从来没有考虑的情况,写篇blog加深下印象 --============================================ ...

  4. 曲演杂坛--重建索引后,还使用混合分区么?(Are mixed pages removed by an index rebuild?)

    原文来自:http://www.sqlskills.com/blogs/paul/mixed-pages-removed-index-rebuild/ 在SQL SERVER 中,区是管理空间的基本单 ...

  5. 曲演杂坛--蛋疼的ROW_NUMBER函数

    使用ROW_NUMBER来分页几乎是家喻户晓的东东了,而且这东西简单易用,简直就是程序员居家必备之杀器,然而ROW_NUMBER也不是一招吃遍天下鲜的无敌BUG般存在,最近就遇到几个小问题,拿出来供大 ...

  6. 曲演杂坛--当ROW_NUMBER遇到TOP

    值班期间研发同事打来电话,说应用有超时,上服务器上检查发现有SQL大批量地执行,该SQL消耗IO资源较多,导致服务器存在IO瓶颈,细看SQL,发现自己都被整蒙了,不知道这SQL是要干啥,处理完问题赶紧 ...

  7. 曲演杂坛--特殊字符/生僻字与varchar

    对于中文版的SQL SERVER,默认安装后使用的默认排序规则为Chinese_PRC_CI_AS,在此排序规则下,使用varchar类型来可以“正常存取”存放中文字符以及一些东南亚国家的字符,同时v ...

  8. 曲演杂坛--使用CTE时踩的小坑:No Join Predicate

    在一次系统优化中,意外发现一个比较“坑”的SQL,拿出来供大家分享. 生成演示数据: --====================================== --检查测试表是否存在 IF(O ...

  9. 曲演杂坛--为什么SELECT语句会被其他SELECT阻塞?

    很多刚入门的DBA在捕获阻塞得时候,会问这么一个问题“为什么这个SELECT语句被那个SELECT语句阻塞了,难道不是共享锁么?” 让我们来做个小测试,首先准备一些测试数据: --========== ...

随机推荐

  1. Python之路(第三篇):Python基本数据类型字符串(二)

    一.基本数据类型1.字符串 str字符串方法介绍(二)a --expandtabs( ) expandtabs( ) 把字符串中的 tab 符号('\t')转为空格参数默认为8,注意字符串原有的空格也 ...

  2. Map 概述

    map定义:将键映射到值的对象.key必须唯一,但是value可以重复.当你添加相同key的值的时候,value会被覆盖. 与之前的collection有什么区别呢? A:Map 存储的是键值对形式的 ...

  3. IOS初级:delegate的使用

    delegate的应用场景:view中的事件,controller做处理(如刷新view中元素等). storyboard的textfield实现点击return实现收起键盘. 首先在ViewCont ...

  4. Ubuntu上搭建Hadoop环境(单机模式+伪分布模式) (转载)

    Hadoop在处理海量数据分析方面具有独天优势.今天花了在自己的Linux上搭建了伪分布模式,期间经历很多曲折,现在将经验总结如下. 首先,了解Hadoop的三种安装模式: 1. 单机模式. 单机模式 ...

  5. C语言基础第四次作业

    题目7-2,九九乘法表 1.实验代码: #include<stdio.h> int main() { int N, i, j, q; scanf("%d",&N ...

  6. 54.NSJSONSerialization类进行json解析(字符串“UTF-8解码”)

    NSDictionary *dic = [NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingAllo ...

  7. floor函数

    C++中 可以用floor函数来截断小数部分 floor(x)返回一个不大于x的整数,有点像取整函数

  8. 深度学习中 epoch,[batch size], iterations概念解释

    one epoch:所有的训练样本完成一次Forword运算以及一次BP运算 batch size:一次Forword运算以及BP运算中所需要的训练样本数目,其实深度学习每一次参数的更新所需要损失函数 ...

  9. 2018.12.17 bzoj4802: 欧拉函数(Pollard-rho)

    传送门 Pollard−rhoPollard-rhoPollard−rho模板题. 题意简述:求ϕ(n),n≤1e18\phi(n),n\le 1e18ϕ(n),n≤1e18 先把nnn用Pollar ...

  10. 第15章 上下文管理器和else块

    #<流流畅的Python>第15章 上下文管理器和else块 #15.1 先做这个,再做那个:if语句之外的else块 #else子句不仅能在if语句中使用,还能在for.while和tr ...