ORACLE数据库表解锁record is locked by another user

    技术2022-07-10  150

    1、查锁

    select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by t2.logon_time; 解锁 alter system kill session 'sid,serial#'; alter system kill session '945,48733';

    1)用dba用户执行以下语句 通过检查数据库表,能够检查出是哪一条语句被死锁,产生死锁的机器是哪一台。

    select username,lockwait,status,machine,program from v$session where sid in (select session_id from v$locked_object)

    如果有输出的结果,则说明有死锁,且能看到死锁的机器是哪一台。字段说明:

    Username:死锁语句所用的数据库用户;Lockwait:死锁的状态,如果有内容表示被死锁。Status: 状态,active表示被死锁 Machine: 死锁语句所在的机器。Program: 产生死锁的语句主要来自哪个应用程序。

    2)用dba用户执行以下语句,可以查看到被死锁的语句。

    select sql_text from v$sql where hash_value in (select sql_hash_value from v$session where sid in (select session_id from v$locked_object))

    查询哪些人或进程被锁使用如下SQL:

    SELECT OBJECT_ID,SESSION_ID,SERIAL# ,a.oracle_username,a.os_user_name,a.process FROM V$LOCKED_OBJECT a , V$SESSION WHERE a.SESSION_ID=SID;
    Processed: 0.010, SQL: 9