发布网友 发布时间:2022-04-07 19:45
共2个回答
懂视网 时间:2022-04-08 00:06
4、 死锁图形事件:
从sqlserver profiler中得到,一般结合1222跟踪标志和sql trace。
首先从errorlog中寻找1222的输出结果,根据输出的时间在跟踪里找到相应的连接。然后分析原因。
解决办法:
尽管死锁不能完全避免,但是可以把机会降到最低:
l 按同一顺序访问对象。
l 避免事务中的用户交互。
l 保持事务简短并处于一个批处理中。
l 使用脚底的隔离级别。
l 调整语句的执行计划,减少锁的申请数目。
按同一顺序访问对象:
如果所有并发事务按同一顺序访问对象,则发生死锁的可能性会降低。
避免事务中的用户交互:
避免编写包含用户交互的事务,因为没有用户干预的批处理的运行速度远快于必须等待用户响应时的查询速度。
保持事务简短并处于一个批处理中:
运行时间越长,等待时间就越长,造成死锁的机会就越高。
使用脚底的隔离级别:
确定事务能否在低隔离级别上运行。尽可能使用较低的隔离级别。
调整语句的执行计划,减少锁的申请数目:
可以从执行计划中找出哪些资源耗得比较多。此时锁的数目也会相应增多。
数据库阻塞和死锁的区别
标签:
热心网友 时间:2022-04-07 21:14
首先P3对R3的资源请求可以得到满足,满足其要求,P3运行完毕,归还所占用的R2资源,从图中删去P3 接下来P2对R2和R3的请求也能得到满足,从而得以执行完毕,归还P2所占用的R1资源,抹去P2 R1归还后,P1对其的请求得到满足,因此P1也可以执行完毕...