精华内容
下载资源
问答
  • 了nowait的时候,马上就会进行反馈“ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源 ”,如果是wait x,那么执行的时候会等待x秒,当x秒过去,资源依旧未解锁,就会反馈跟nowait一样的...
    当执行update的时候,不加nowait/wait x的时候,当数据记录被锁住的时候,是一直处于等待状态,直到解锁。而加了nowait的时候,马上就会进行反馈“ORA-00054错误,内容是资源正忙但指定以 NOWAIT 方式获取资源 ”,如果是加的 wait x,那么执行的时候会等待x秒,当x秒过去,资源依旧未解锁,就会反馈跟nowait一样的信息。
    展开全文
  • 在oracle中,如果只是select 的话,Oracle是不会任何锁的,也就是Oracle对 select 读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且修改的结果可能影响到你目前select语句的结果...
    • 首先一点

    在oracle中,如果只是select 的话,Oracle是不会加任何锁的,也就是Oracle对 select 读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且修改的结果可能影响到你目前select语句的结果,但是因为没有锁,所以select结果为当前时刻表中记录的状态。

    • 他们三个共同点:

    当使用select for update 或select for update wait或select for update nowait,那么oralce会给符合where条件的数据行加上一个行级锁。

    • select for update

    但是如果你的select 语句加了for update,那么就不是上面这回事了,当oracle发现select的当前结果集中的一条或多条正在被修改(注意:当数据被修改时,此时的数据行是被加锁的),那么他就会等到当前当前结果集被修改完毕并且commit之后才进行select操作,并对结果集进行加锁。同样的,如果查询语句发出后,其他会话需要修改结果集中的一条(或几条数据)也许要等到查询结束(commit)之后,才可以执行修改操作。

    代码如下:
    新建SQL窗口1,(相当于新建一个session会话)
    在这里插入图片描述
    在这里插入图片描述
    for update 对整个结果集进行了加锁,意味着在当前session进行commit之前,任何其他的session进行update、delete、insert操作都会进行等待

    新建SQL窗口2(相当于新建一个session会话)
    在这里插入图片描述
    在这里插入图片描述
    显示执行中,等待会话一的查询执行完成

    现在我们将会话一的事务提交(commit)
    在这里插入图片描述
    会话二的update语句执行成功
    在这里插入图片描述

    • select for update nowait

    for update和for update nowait都会对查询到的当前结果集进行加锁,所不同的是,当有另外的会话在修改当前结果集中的数据,select for nowait所进行的查询操作不会进行等待,当发现结果集中的一些数据被加锁,立刻返回 “ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源”。测试代码如下:

    新建一个SQL窗口1(相当于新建一个会话)

    `update cwa3001bak set price=3 where ID=1`
    

    更新cwa3001bak 表的一条数据,但是不进行commit操作

    然后新建SQL窗口2(相当于新建一个会话)select for update nowait操作

        select * from cwa3001bak for update nowait
    

    在这里插入图片描述

    • 总结分析:

    因为会话一,并没有commit所以cwa3001bak 中的ID=1的行被加锁了,
    所以当会话二进行select for update nowait检索到ID=1的数据行被加锁了,
    就立刻返回 “ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源”的错误。

    接下来我们对会话一进行commit操作,
    在这里插入图片描述
    在执行会话二的select查询,ok,可以查出来了,并且对当前数据集进行了加锁操作,其他会话想要进行修改操作,必须等到会话二commit之后
    在这里插入图片描述

    • select for update wait

    它也会对查询到的结果集进行加锁,select for update wait与select for update nowait不同的地方是,当有另外的会话对它的查询结果集中的某一行数据进行了加锁,那么它不会像nowait一样,立即返回"ORA-00054错误",而是它支持一个参数,设定等待的时间,当超过了设定的时间,那一行数据还处于加锁的状态,那么它也会返回“ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源”。测试代码如下:

    首先新建SQL窗口1(相当于新建一个会话)执行update 语句,但是不进行commit操作,那么当前数据行将被lock

        update cwa3001bak  set price=3 where ID=1
    

    接着新建SQL窗口2(相当于新建一个会话),在执行select for update wait 6,如果当前查询检索的数据集中,有被加锁了的行数据,那么等待6秒,如果6秒后,其他会话,还没有执行commit释放被加了锁的数据行的话,那么返回“ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源”。

        select * from cwa3001bak for update wait 6
    

    执行语句6秒后,报错
    在这里插入图片描述
    最后对会话一(SQL窗口一)进行commit操作
    在这里插入图片描述
    紧接着执行会话二(SQL窗口二)中的sql语句,此时被加锁的数据行被释放
    在这里插入图片描述
    正常的检索除了数据行,当时当前数据集被加锁,其他会话想操作此数据集,必须等会话二中的事务commit之后,才可以进行修改

    展开全文
  • 在执行update的时候,不nowait/wait x的时候,当数据记录被锁住的时候,会一直处于等待状态,直到资源锁定被释放; 而了nowait的时候,马上就会进行反馈“ORA-00054错误,内容是资源正忙,但指定以NOWAIT方式...

    在执行update的时候,不加nowait/wait x的时候,当数据记录被锁住的时候,会一直处于等待状态,直到资源锁定被释放;

    而加了nowait的时候,马上就会进行反馈“ORA-00054错误,内容是资源正忙, 但指定以 NOWAIT 方式获取资源 ”;

    如果是加的 wait x,那么执行的时候会等待x秒,当x秒过去,资源依旧未被释放,就会反馈跟nowait一样的信息。

    此博客来自我之前在CSDN的迁移。

    原文链接:https://blog.csdn.net/qq_17153527/article/details/80267656

    转载于:https://www.cnblogs.com/wshx940621/p/9101428.html

    展开全文
  • oracle中,select语句,如果不加for update,则oracle不会添加任何锁;  如果为select .....for update ,则oracle会添加锁,如果数据正在被修改,则此条查询必须等待,等到修改结束,即commit后,才能立即查

               oracle中,select语句,如果不加for update,则oracle不会添加任何锁;

               如果为select .....for update ,则oracle会添加锁,如果数据正在被修改,则此条查询必须等待,等到修改结束,即commit后,才能立即查询,返回结果。

               如果为select ... for update nowait,若所查询数据正在被修改,则不会等待修改结束,而是立即返回“ORA-00054”错误,

               for update和for update nowait 都是添加的行级锁,即只满足where子句 的数据被锁住。

    展开全文
  • For update 与for update nowait/wait 小解

    千次阅读 2013-10-20 22:40:20
    For update 与for update nowait/wait 小解   1、FOR UPDATE 和FOR UPDATE NOWAIT 的区别: 首先一点,如果只是SELECT 的话,Oracle是不会任何锁的,也就是Oracle对SELECT 读到的数据不会有任何...
  • 一、 FOR UPDATE和FOR UPDATE NOWAIT的区别:  首先一点, 如果只是SELECT的话, ORACLE是不会任何锁的, 也就是ORACLE对SELECT读到的数据不会有任何限制, 虽然这时候有可能另外一个进程正在修改表中的数据, 并且...
  • for update 和for update nowait主要区别在于是否等待,如果不nowait,在执行select时就会报错,如果了nowait,在执行select时就会等待,直至锁被释放。 首先我们使用两个sql: 1.select * f
  • oracle for update和for update nowait的区别

    千次阅读 2018-08-04 13:28:44
    1、for update 和 for update nowait 的区别: 首先一点,如果只是select 的话,Oracle是不会任何
  • mybatis中for update和for update nowait的区别和使用 ...for update 和for update nowait主要区别在于是否等待,如果nowait,在执行select时就会报错,如果不nowait,在执行select时就会等待,...
  • 要搞清楚for update和for update...用for update,如果这个行已经被其它的事务了锁,那么它就在那里等待对方释放锁然后自己加锁,所以看起来它就像你所说的“hang”住了。用for update nowait,功能也是一样的,即...
  • 二者的区别(nowait):如果查询的资源已经了锁,例如正在被修改,那么for update会等待锁释放后执行查询,请求被阻塞。加上nowait后,如果发现结果集中有资源被锁,会立即抛出异常“ORA-00054错误,内容是资源正...
  • 使用waitfor 语句

    2018-03-30 13:47:00
    waitfor delay ’00:01:15’ print N’到时间了’--也可以不N 字符串前面放N,表示该字符串是unicode编码。 但注意:首先应该是大写的N,小写不对。其次N应该放在字符串之前,即N后面紧接着单引号,不能有空格。...
  • for update 和 for update nowait的区别首先一点,如果只是select 的话,Oracle是不会任何锁的,也就是Oracle对 select 读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且修改的...
  • 1、for update 和 for update nowait 的区别 首先一点,如果只是select 的话,Oracle是不会任何锁的,也就是Oracle对 select 读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且...
  • 1、for update和for update nowait的区别: 首先一点,如果只是select的话,Oracle是不会任何锁的,也就是Oracle对select读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且...
  • 1、for update和for update nowait的区别:  首先一点,如果只是select的话,Oracle是不会任何锁的,也就是Oracle对select读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且修改...
  • 一.for update 和 for update nowait 的区别  首先一点,如果只是select 的话,Oracle是不会任何锁的,也就是Oracle对 select 读到的数据不会有任何限制,虽然这时候有可能另外一个进程正在修改表中的数据,并且...
  • for update 和 for update nowait 的区别: 转自:http://www.cnblogs.com/quanweiru/archive/2012/11/09/2762223.html      首先一点,如果只是select 的话,Oracle是不会任何锁的,也就是Oracle对 ...

空空如也

空空如也

1 2 3 4 5 ... 16
收藏数 317
精华内容 126
关键字:

for加wait