[转帖]SELECT ... FOR UPDATE(WAIT/NOWAIT)命令与ORACLE锁_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 6032 | 回复: 0   主题: [转帖]SELECT ... FOR UPDATE(WAIT/NOWAIT)命令与ORACLE锁        下一篇 
derek
注册用户
等级:中校
经验:1550
发帖:209
精华:0
注册:2011-7-21
状态:离线
发送短消息息给derek 加好友    发送短消息息给derek 发消息
发表于: IP:您无权察看 2011-8-16 15:26:23 | [全部帖] [楼主帖] 楼主

oracle锁的排队机制:
    请求锁定需要排队。如果某个会话请求一个锁定,但是由于其他会话已经锁定了指定记录或对象而无法获得所需的锁定,那么这个会话将会等待。此时,可能多个会话都在等待访问相同记录或对象,在这种情况下,ORACLE会跟踪这些会话请求锁定的顺序。
    如果不希望某个会话在无法获得锁定时进行排队等候,那么避免排队的唯一方式是使用SELECT ... FOR UPDATE(子句WAIT/NOWAIT)命令。SELECT ... FOR UPDATE命令会采用专用的模式来选择和锁定记录。如果某条记录已被锁定,那么在锁定被释放前,SELECT ... FOR UPDATE语句会像DML语句一样进行排队并挂起会话。使用子句NOWAIT或WAIT <n>就可以避免挂起会话,其中<n>是以秒为单位的数值。

     我们在使用ORACLE进行数据处理的时候,有时需要对查询出来的记录进行锁定,禁止其他进程对该记录进行修改操作。
    oracle数据库提供了一种利用SELECT的FOR UPDATE子句实现的方法(可能sqlserver也有这个功能,但是没有测试过)。通过select * from ta for update方法,可以将查询结果中的记录进行update锁定,及不允许其他进行对这些记录进行修改。我们还可以通过select * from a for update of a.a;(a表的a列)对记录中的某一列进行锁定。
    当我们使用FOR UPDATE子句将记录锁定后,其他进程在对锁定记录进行update或delete操作时,就会处于停顿状态,等待解锁。当锁定进程释放锁定以后才会继续执行。如果不想其他进行进入停顿状态,可以用nowait子句,直接返回操作异常信息,提示操作的记录处于锁定状态不能进行修改。

     所以我们在做多线程同步时,可以通过select * form ta for update nowait的方法防止多个进程同时操作同一数据。

     这种锁定方式是建立在数据库连接的基础上,一旦连接断开或者锁定进程commit时,这种锁定就自动解除。同时这种锁定方式是一种update锁定,锁定时不影响其他的select操作。




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论