首页 新闻 赞助 找找看

SQL SERVER死锁

0
悬赏园豆:50 [待解决问题]

服务器停电后造成查询语句死锁,请教办法,也查了网上很多解决办法,但是都不行,

Lastone_key的主页 Lastone_key | 初学一级 | 园豆:152
提问于:2018-07-23 09:27
< >
分享
所有回答(2)
0

查看锁表进程

select l.os_user_name, l.oracle_username, object_name, o.object_type,
       o.created, s.program, s.sid, s.serial#, p.spid
  from v$locked_object l, dba_objects o, v$session s, v$process p
where l.object_id = o.object_id
   and l.session_id = s.sid
   and s.paddr = p.addr;

杀掉锁表进程方法一:

alter system kill session 'sid,serial#';

 
如果利用上面的杀掉锁表进程方法一杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:
select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=234 (234是上面的sid)
在OS上杀死这个进程(线程):
1)在unix上,用root身份执行命令:
#kill -9 12345(即第3步查询出的spid)
2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
例:c:>orakill orcl 12345
^keepHungry$ | 园豆:516 (小虾三级) | 2018-07-23 10:03
0

首先你要确认下 是否是死锁引起的。先判断下 是那个表引起的死锁。服务器正常运转时,突然断电 ,是不会引起死锁的。建议楼主,确认下故障,在寻找原因吧。

温情亿度开发者 | 园豆:315 (菜鸟二级) | 2018-07-23 22:48
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册