文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired

2023-10-01 19:51

关注

1. 原因分析

出现这个问题的原因是正在执行的操作请求的资源正被其他事务锁定。即上述异常代表有事务没有提交,因为刚好有表正在被操作且被锁,因此资源还未释放,导致处理需要等待资源释放。

之后才搞清楚原来是有人对表执行了 delete 的 sql 语句,然后又突然给中断了,既没 commit 提交,也没 rollback 回滚,而导致的数据库锁表。即由于其他 Session 已经对目标表做了操作,并且已经有排他锁在表上了,所以新的 Session 无法再对表进行 DDL/MDL(除select语句外)操作。


2. 解决办法

v$locked_object 视图记录锁表相关的内容。这个视图的结果需要有锁表的情况才会出现,主要可以通过它 session_id 来关联其他表。

2.1 检查哪个用户占用资源


session_id:就是 session 会话 id。
owner:操作表的用户名
object_name :表名
根据出问题的表来找到所需要的 session_id。

select l.session_id,o.owner,o.object_name from v$locked_object l,dba_objects o where l.object_id=o.object_id;

2.2 利用查出来占用资源的 session_id,查出更加详细的信息


下面的 sid 就是上面查询出来的 session_id。这个查询将返回会话 ID、序列号、数据库用户名、操作系统用户名。

SELECT sid, serial#, username, oSUSEr,terminal,program ,action, prev_exec_startFROM v$session where sid = 143;

2.3 根据上面查出来的 sidserial# 杀掉占用资源的session会话

alter system kill session '143,29637';

参考链接:Oracle报错:ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired_oracle报错00054_冷漠;的博客-CSDN博客

来源地址:https://blog.csdn.net/qq_26893841/article/details/129830720

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯