SQLServer模拟死锁以及查询死锁进程和表

 时间:2026-02-14 12:56:37

1、连接SQLServer

SQLServer模拟死锁以及查询死锁进程和表

2、新建一个查询框

SQLServer模拟死锁以及查询死锁进程和表

3、创建2个表:

CREATE TABLE Lock1(C1 int default(0));


CREATE TABLE Lock2(C1 int default(0));
INSERT INTO Lock1 VALUES(1);
INSERT INTO Lock2 VALUES(1);

SQLServer模拟死锁以及查询死锁进程和表

4、继续新建一个文件执行:

Begin Tran


  Update Lock2 Set C1=C1+1;
  WaitFor Delay '00:00:30';
  SELECT * FROM Lock1
Rollback Tran;

SQLServer模拟死锁以及查询死锁进程和表

5、再新增一个文件执行:

Begin Tran


  Update Lock1 Set C1=C1+1;
  WaitFor Delay '00:00:30';
  SELECT * FROM Lock2
Rollback Tran;

SQLServer模拟死锁以及查询死锁进程和表

6、这样就能模拟死锁报错了

SQLServer模拟死锁以及查询死锁进程和表

7、然后通过这个SQL查报错的表和进程:


SELECT request_session_id spid, OBJECT_NAME( resource_associated_entity_id )
tableName FROM sys.dm_tran_locks WHERE resource_type = 'OBJECT'

SQLServer模拟死锁以及查询死锁进程和表

  • foobar2000如何在播放列表中显示文件名
  • 日常生活中该如何养殖皋月杜鹃?
  • 韩式辣炒五花肉
  • 勇者大冒险激活码怎么获得?勇者大冒险好不好玩
  • 打水光针这八个问题你弄清楚了吗?
  • 热门搜索
    贷后管理是什么意思 什么项目赚钱 nemo什么意思 一尘不染什么意思 usd是什么意思 感慨的意思 中药白芍的功效与作用 姹紫嫣红的意思 买房子需要注意什么 胎儿入盆什么感觉