解决oracle数据库 ora-00054:resource busy and acquire with NOWAIT specified 错误
本人在使用pl/sql developer 客户端调用存储过程进行操作时发现中途卡机然后强制终止pl/sql developer 之后,oracle就一直出现锁相关的错误。
经分析认为在调用存储过程时对表进行了DDL语句操作时导致了悲观封锁。客户端卡机后oracle一直没有对这个锁进行释放且一直不会完成释放导致错误。
需要对此会话进行强制杀掉:
1. 查询当前被锁的对象
SELECT * FROM V$LOCKED_OBJECT WHERE ORACLE_USERNAME= 'ATHENA';
SQL> SELECT * FROM V$LOCKED_OBJECT WHERE ORACLE_USERNAME= 'ATHENA';
XIDUSN XIDSLOT XIDSQN OBJECT_ID SESSION_ID ORACLE_USERNAME OS_USER_NAME PROCESS LOCKED_MODE
---------- ---------- ---------- ---------- ---------- ------------------------------ ------------------------------ ------------ -----------
19 11 79134 76618 436 ATHENA Administrator 3512:1272 3
11 28 74487 76617 574 ATHENA Administrator 2412:3928 3
20 25 75512 76620 594 ATHENA Administrator 4064:4060 3
2. 查询session信息
SQL> SELECT v.sid,v.SERIAL#,v.USERNAME,v.ACTION FROM v$session v WHERE v.sid IN (SELECT session_id FROM v$locked_object WHERE ORACLE_USERNAME= 'ATHENA') AND V.MACHINE='NBCB\KJB-080701N';
SID SERIAL# USERNAME ACTION
---------- ---------- ------------------------------ --------------------------------
436 62365 ATHENA 测试窗口 - procedure PROC_HIS_AR
574 60824 ATHENA 测试窗口 - procedure PROC_HIS_AR
594 15217 ATHENA 测试窗口 - procedure PROC_HIS_AR
3. 杀会话
语法:
ALTER SYSTEM KILL SESSION 'SID,SERIAL#';
例如:
ALTER SYSTEM KILL SESSION '436,62365';
返回:ora-00031:session marked for kill. 此会话没有被杀掉,只是标记为要杀掉。
可查询
SELECT spid,osuser,s.PROGRAM FROM v$session s,v$process p WHERE s.PADDR=p.ADDR AND s.SID=436;
然后登陆到操作系统上使用如下命令进行操作系统级别的杀进程
语法:orakill sid thread 或者 #kill -9 spid
例如: orakill 数据库实例名 ${spid};
实在不行只能重启数据库
分享到:
相关推荐
Oracle数据库在处理并发事务时,可能会遇到“ORA-00054: resource busy and acquire with NOWAIT specified”错误,这通常意味着当前操作试图获取一个已被其他事务占用的资源,而该请求又指定了不允许等待(NOWAIT)...
在删除表空间时可能会遇到问题,比如描述中提及的"ora-00054: resource busy and acquire with nowait specified"错误,这意味着有活动的事务或锁定阻止了表空间的删除。要解决这个问题,需要找出并结束那些占用资源...
- `java.sql.SQLException: ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired`: 这表示尝试获取的资源已被其他会话占用。可以调整事务隔离级别或增加等待时间。 7. **游标问题** ...
#### ORA-00054: Resource busy and acquire with NOWAIT specified - **描述**:资源忙且获取时指定了 NOWAIT。 - **解决方法**:移除 NOWAIT 或等待资源可用。 #### ORA-00055: DML on a dictionary managed ...
##### ORA-00054: Resource Busy and Acquire With NOWAIT Specified - **描述**:资源繁忙并且使用NOWAIT指定获取。 - **解决方法**: - 尝试不使用NOWAIT选项重新获取资源。 - 杀死持有资源的进程。 ##### ORA-...
#### ORA-00017: Resource busy and acquire with NOWAIT specified - **解释**: 当尝试获取一个资源(如锁)时,如果该资源被其他进程占用,并且请求中指定了`NOWAIT`选项,则会触发此错误。 - **解决方案**: 如果...
### ORA-00017: Resource busy and acquire with NOWAIT specified 在尝试锁定资源时,如果资源当前正被其他事务占用,并且使用了NOWAIT选项,则会引发此错误。这通常发生在并发环境中,多个事务试图同时访问同一...
2. **ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired** - **含义**:尝试获取已被其他会话锁定的资源时,如果使用了NOWAIT选项或者等待超时,则会抛出此错误。 - **原因**:另...
在日常操作中,数据库用户可能会遇到各种问题,其中“ORA-00054: resource busy and acquire with nowait specified”是一个常见的错误,它通常出现在并发操作环境下,比如当一个事务正在处理数据而其他事务尝试立即...
2. **ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired** - **解释**:这个错误通常发生在尝试获取锁定资源时资源正忙,并且使用了NOWAIT选项或超时时间已过期。 - **解决方案**:...
例如,ORA-00001: uniqueness constraint violated(唯一性约束违反),ORA-00054:resource busy and acquire with NOWAIT specified(资源忙并指定 NOWAIT)。 ### 非预定义的异常处理 非预定义的异常处理是...
这部分内容列举了常见的异常消息及其代码,例如ORA-00001 (unique constraint violated)、ORA-00054 (resource busy and acquire with NOWAIT specified or timeout expired)等,这些都是数据库管理员和技术支持人员...
如果这行数据当前已被其他事务锁定,`UPDATE NOWAIT`将不会阻塞并等待锁的释放,而是立即抛出一个`ORA-00054: resource busy and acquire with NOWAIT specified`异常。这使得你可以快速响应数据被锁定的情况,而...
在进行数据库操作时,比如对数据表进行插入(INSERT)、更新(UPDATE)或删除(DELETE)操作,或者是添加主键(PRIMARY KEY)或索引(INDEX)时,可能会遇到ORA-00054错误:“resource busy and acquire with NOWAIT...
- 收到类似于“ORA-00054: resource busy and acquire with NOWAIT specified or timeout expired”的错误提示。 这种情况的发生主要由以下几点原因造成: - **并发控制机制**:Oracle使用行级锁定来管理并发访问。...
ORA-00054: resource busy and acquire with NOWAIT specified ``` 这是因为 DDL 语句需要表上的排他锁,而这与 DML 语句已在表上放置的共享锁相冲突。因此,试图在表中插入一个列的这条 DDL 语句会失败。需要...
如果尝试在锁定期间执行DDL,可能会遇到`ORA-00054: resource busy and acquire with NOWAIT specified`错误。 5级锁在处理主外键约束的UPDATE或DELETE时出现,以确保参照完整性。当更新或删除涉及关联表的记录时,...