现象
DB2锁监控抓到锁等语句,语句为一个游标cursor
SELECT * FROM KEN_CUSTOMER where bankorg_id=:a and customer_id=:b for update;
结论
DB2中的select...for update
- 如果是动态SQL,只有显式指定RR或RS隔离级别时,才会产生U锁。U锁和S锁兼容,与U锁不兼容。Update之后U锁变为X锁。
- 如果是静态SQL,定义了游标cursor之后,即使没有显式指定RR或RS隔离级别,为默认的CS隔离级别时,当fetch游标数据时会产生U锁。
问题现象复合第二种情况,同一笔数据并发查询测试,产生锁等。