SQL0911N The current transaction has been rolled back because of a deadlock or timeout. Reason code "68".
SQL0911N 因为死锁或超时,所以当前事务已回滚。原因码为 "68"。
性能测试时出现此问题,开始以为是死锁,后来查到出现SQL0911N 并非一定是死锁,还取决于原因码是哪一个。
SQL0911N 因为死锁或超时,所以当前事务已回滚。原因码为 "<原因码>"。
说明:
当前工作单元参与了未解决的对象争用,因此必须回滚。
原因码如下所示:
2 由于死锁而导致事务已回滚。
68 由于锁定超时而导致事务已回滚。
72 因为存在与事务中所涉及的 DB2 Data Links Manager 有关的错误,所
以事务已回滚。
注: 必须再次输入与工作单元相关的更改。
应用程序已回滚至上一次 COMMIT。
本人遇到的错是锁等待超时而并非死锁。当然锁等待超时也意味着存在性能问题。
锁等待超时解决办法:
1.优化相关sql
2.延长超时设置合适大小
死锁分析方法:
db2对死锁进行分析需借助死锁监视器,但打开死锁监视器会有额外的开销,一般情况下禁用死锁监视器。
具体操作可见官网https://www.ibm.com/developerworks/cn/data/library/techarticles/dm-1004lockeventmonitor/