如何只对表的一个字段加锁

billlyh 2015-04-11 10:11:59
以为可以用select ... where For update of 表名.列名实现,但经测试

select * from emp where empno = 7369 for update of sal; 这条语句是不是意味着只对表中的7369 这一行的sal字段的数据进行了上锁,
是对整行加锁的,效果和select * from emp where empno = 7369 for update; 一样


哪位能解决这个问题??
...全文
284 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
卖水果的net 2015-04-13
  • 打赏
  • 举报
回复
oracle 没有单独的列锁,只有行锁和表锁。 你要锁要某一列,必须要锁定那一整行。

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧