前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >[DB2] Select ... For Update锁等一例

[DB2] Select ... For Update锁等一例

原创
作者头像
夜半钟鸣
修改2021-02-22 17:58:35
1.8K0
修改2021-02-22 17:58:35
举报
文章被收录于专栏:小树洞小树洞

现象

DB2锁监控抓到锁等语句,语句为一个游标cursor

代码语言:javascript
复制
 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锁。

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 现象
  • 结论
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档