• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Oracle 11g DDL 的 wait选项(DDL_LOCK_TIMEOUT)

mysql 搞代码 4年前 (2022-01-09) 19次浏览 已收录 0个评论

DDL命令需要排它锁的内部结构。如果这些锁不可用,将返回一个rdquo; ORA-00054: resource busyrdquo;,当试图修改频繁访问的对象

DDL命令需要排它锁的内部结构。如果这些锁不可用,将返回一个” ORA-00054: resource busy”,当试本文来源gao($daima.com搞@代@#码$网图修改频繁访问的对象时,这可能特别让人沮丧,为了解决这个问题Oracle 11g 包含了DDL_LOCK_TIMEOUT参数,可以在实例或者会话级别分别使用alter system 和 alter session命令。

DDL_LOCK_TIMEOUT 表示一个DDL命令等待锁可用的秒数在抛出”resource busy”错误之前。默认值是0(表示NOWAIT)。

SQL> create table ddl_lock_test (

id number

);

SQL> insert into ddl_lock_test values ( 1 );

———–创建一个测试表,并插入一条数据,,但不commit;

———–新开一个session,在session 级别设置 DDL_LOCK_TIMEOUT 为一个非0值并试图在表上加一列;

SQL> alter session set ddl_lock_timeout = 20;

SQL>alter table ddl_lock_test add (

name varchar2(20)

);

——–这个会话会等待20秒在失败之前.

alter table ddl_lock_test add (name varchar2(20))

*

ERROR at line 1:

ORA-00054: resource busy and acquire with NOWAIT specified

—-若我们重复alter table 命令并在20秒内commit 第一个session 的 insert , alter table 将会返回执行成功消息。

SQL>alter table ddl_lock_test add (

name varchar2(20)

);

Table altered.

SQL>


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Oracle 11g DDL 的 wait选项(DDL_LOCK_TIMEOUT)

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址