带shell脚本的ORA-00054错误

日期: 2009-06-02 作者:Brian Peasland翻译:April 来源:TechTarget中国 英文

问:我写了一个叫SQL的shell脚本。但SQL却删去了只属于该程序的temp。这些shell脚本在预定的包中运行。有时会提示我”ORA-00054: resource busy and acquire with NOWAIT specified.” 。

这个错误是在我删去临时表的时候出现的。因为临时表只属于特殊的程序,所以其他的程序就没有机会对它锁定。因为这些都是预定的任务,我也不可能登陆到这个V$SESSION表。这个错误并不是每天都会出现,只是有是会出现。

你能告诉我出现这一问题真正的原因吗?   答:TRUNCATE TABLE命令是一个DDL命令。和DML命令不一……

我们一直都在努力坚持原创.......请不要一声不吭,就悄悄拿走。

我原创,你原创,我们的内容世界才会更加精彩!

【所有原创内容版权均属TechTarget,欢迎大家转发分享。但未经授权,严禁任何媒体(平面媒体、网络媒体、自媒体等)以及微信公众号复制、转载、摘编或以其他方式进行使用。】

微信公众号

TechTarget微信公众号二维码

TechTarget

官方微博

TechTarget中国官方微博二维码

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找到你想要得到的信息。

作者

Brian Peasland
Brian Peasland

Techtarget旗下Searchoracle网站的资深专家,有16年IT行业经验、计算机科学硕士、专攻数据库方向,曾担任系统管理员等职。此外,他还获Oracle 7.3、8和8i的OCP数据库管理员证书,目前为SGT Inc.公司首席DBA。

翻译

April
April

相关推荐

  • 避免Oracle错误

    我如何才能避免 ORA-01501、ORA-00200、ORA-00202、ORA-27038以及OSD-04010这些错误?

  • 特殊Batch Process并行运行时出现死锁错误

    为什么在特殊Batch Process并行运行时会出现死锁错误?出现这种错误情况时我们应该如何处理?

  • 处理ORA-01251错误

    接到客户的claim:用户通过ERP无法登录到服务器,检查了下中间件运行正常,看了下中间件的日志提示无法连接数据库!

  • AIX下bosboot报0301-154处理

    客户安装软件,在安装过程中报……,于是使用如下命令检测……;参照了IBM官方给的一个方法,但是发现这个方法有些问题。