本文共 548 字,大约阅读时间需要 1 分钟。
--start [quote] DB2 SQL error: SQLCODE: -911, SQLSTATE: 40001, SQLERRMC: 2 Message: The current transaction has been rolled back because of a deadlock or timeout. Reason code "2". [/quote] 昨天,执行了一条很简单的SQL,却怎么也执行不成功,报的错误如上所示,是死锁。既然是死锁,那就过一会执行吧。等了一会后仍然死锁。到底是哪个事务和哪个事务相互锁了呢?查询了老半天才发现原来这条SQL语句更新的数据量非常大,导致锁升级,然后锁升级又失败了,导致了死锁。原来锁升级失败会导致死锁。所以,通常我们应该将LOCKLIST和MAXLOCK参数调整到足够大,尽量避免锁等待、锁升级,发挥数据库的最大并发性。 --[b]更多参见[/b]:[url=http://iamwave.iteye.com/blog/649715]DB2 系列文章目录[/url] --[b]声明:转载请注明出处[/b] --last updated 2010.3.15 --written by wave at 2010.3.15 --end