带shell脚本的ORA-00054错误

 
   | |

导读:专家在本文中介绍如何解决带shell脚本的ORA-00054错误:resource busy and acquire with NOWAIT specified。

关键词:Oracle错误 ORA-00054错误 带shell脚本的ORA-00054错误

正在加载数据... 【TechTarget中国原创】我写了一个叫SQL的shell脚本。但SQL却删去了只属于该程序的temp。这些shell脚本在预定的包中运行。有时会提示我"ORA-00054: resource busy and acquire with NOWAIT specified." 。这个错误是在我删去临时表的时候出现的。因为临时表只属于特殊的程序,所以其他的程序就没有机会对它锁定。由于这些都是预定的任务,我也不可能登陆到这个V$SESSION表。这个错误并不是每天都会出现,只是有是会出现。你能告诉我出现这一问题真正的原因吗?

【TechTarget中国原创】问:我写了一个叫SQL的shell脚本。但SQL却删去了只属于该程序的temp。这些shell脚本在预定的包中运行。有时会提示我"ORA-00054: resource busy and acquire with NOWAIT specified." 。这个错误是在我删去临时表的时候出现的。因为临时表只属于特殊的程序,所以其他的程序就没有机会对它锁定。因为这些都是预定的任务,我也不可能登陆到这个V$SESSION表。这个错误并不是每天都会出现,只是有是会出现。你能告诉我出现这一问题真正的原因吗?

  答:TRUNCATE TABLE命令是一个DDL命令。和DML命令不一样(INSERT, UPDATE, DELETE),DDL命令不会去等着释放锁。相反,DDL命令会失败而且会发生ORA-00054错误。

  临时表并不属于某个程序。如果你的TRUNCATE TABLE命令导致了ORA-00054错误,那么这些锁、甚至是共享锁就造成了这一问题。可能你之前执行代码时并没有释放锁,或者是一些其他的程序或代码有这个锁。唯一的办法就是在问题出现时查询V$LOCK。查询V$LOCK,然后再查询V$SESSION,就会告诉你谁锁住了你的对象。在我的网页上,我写了一篇题为《解决用户问题》的白皮书。这篇白皮书会告诉你如何通过查询V$LOCK找到你想要得到的信息。

 
查看全文
 
 
 
 
 

Oracle错误

 
Oracle通常将没有引号的标识符转换成大写键盘的,在提交查询时你必须给列名加入双引号以避免出现错误。
 
在Oracle中,CLOB列包含了分隔的10位代码,如何避免重复的代码是一件比较麻烦的事,专家给出了三种解决方法,你可以根据自身情况进行选择。
 
在Windows 2003操作系统下安装了Oracle 8i数据库软件,使用的时候发生Ora-1067错误,出现这一问题的原因是什么,Oracle专家给出了解释。
 
如何在触发器内部建立一个索引,专家说如果DML是EXECUTE IMMEDIATE语句的一部分,你就可以在触发器中执行DML。
 
在进行Oracle实例维护时出现内存分配问题,导致无法启动新连接,正在运行的会话很慢,专家将给出解决方案。
 

登录TechTarget中国

关闭
本服务仅向TechTarget中国的会员开放,请登录或立即免费注册
电子邮件地址:
请输入您的电子邮件地址
密码:
下次自动登录