解决sqlserver死锁问题

创造死锁

-- 开始事务
BEGIN TRANSACTION 

update job set create_user='0000' where id = '1'

WAITFOR DELAY '02:00'

-- 执行查询
select * from job where id = '1';

解决方法

方法一

  1. 打开sqlserver管理工具,新建sql查询tab
  2. 执行select * from master.sys.sysprocesses where dbid=db_id(‘数据库名’)
  3. 然后会查询到具体有哪个在连接到此数据库
  4. 直接KILL spid的具体数值就可以了

方法二

-- 首先查询
select    
    request_session_id spid,   
    OBJECT_NAME(resource_associated_entity_id) tableName    
from    
    sys.dm_tran_locks   
where    
    resource_type='OBJECT' 
-- 然后执行
	kill 67;

注意事项:
有些用户连接可以在kill掉后自动重建,但期间有一段时间,如果碰到这种情况,需要在执行完kill命令后立即执行脱机操作

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQL Server死锁是指在数据库中发生的两个或多个事务相互等待对方所持有的资源而导致的无法继续执行的情况。SQL Server数据库引擎会自动检测死锁,并选择其中一个会话作为死锁受害者终止事务,并显示错误以打破死锁解决SQL Server死锁问题的方法有两种: 1. 使用Update lock语法:对于先读后写类型的操作,可以使用带有updlock参数的select语句,这样可以在读取数据的同时锁定该数据,避免死锁的发生。例如:select * from table1 with(updlock) where ... 2. 调整程序逻辑:如果死锁是由于程序的BUG导致的,除了使用上述方法外,还应该仔细分析程序的逻辑。尽量避免同时锁定两个资源,如果必须同时锁定两个资源,要按照相同的顺序来锁定资源,以避免死锁的发生。 通过采取这些方法,可以有效地解决SQL Server死锁问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SQL Server的死锁说明](https://blog.csdn.net/Long_xu/article/details/130075691)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Sql Server 数据库死锁介绍和解决方法](https://blog.csdn.net/qq_41024101/article/details/116952205)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值