DB2 SELECT FOR UPDATE锁等一则

现象

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锁。

问题现象复合第二种情况,同一笔数据并发查询测试,产生锁等。

DB2 SELECT FOR UPDATE锁等一则

上一篇:Android从文件读取图像显示的效率问题


下一篇:mysql锁 锁定范围