更新一个表时,在提交之前oracle会在这个表上加上1个tm锁,确保表的结构不会改变。这个时候,如果另一个会话在该表格上执行alter
更新一个表时,在提交之前oracle会在这个表上加上1个tm锁,确保表的结构不会改变。
这个时候,,如果另一个会话在该表格上执行alter或者drop命令,就会立即得到以下错误信息:
tony@ora11gr2> drop table t;
drop table t
*
第 1 行出现错误:
ora-00054: 资源正忙, 但指定以 nowait 方式获取资源, 或者超时失效
在oracle11gr2中,可以设定ddl_lock_timeout参数让ddl等待。
例如在执行drop table之前,执行
alter session set ddl_lock_timeout=30;
让drop table等待30秒,如果30秒内,另外那个锁定待删除表格的会话提交或者回滚了事务,
这个drop table命令就会得到执行,否则就会在30秒后产生1个ora-00054:错误。