Oracle的KILL锁表及清除session方法

本文提供了一种解决Oracle数据库中锁定表的方法,包括查询锁定表及其相关会话信息,终止锁定会话,并杀死对应系统进程的步骤。同时介绍了涉及的视图如V$LOCKED_OBJECT、V$SESSION和V$PROCESS等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、处理过程

      1.通过查找出已被锁定的数据库表及相关的sid、serial#及spid:

        select object_name as 对象名称,s.sid,s.serial#,p.spid as 系统进程号

        from v$locked_object l , dba_objects o , v$session s , v$process p

        where l.object_id=o.object_id and l.session_id=s.sid and s.paddr=p.addr;

        2.在数据库中灭掉相关session:

       alter system kill session 'sid,serial#';

      --sid及serial#为第一步查出来的数据

        3.从系统中灭掉与该session对应的进程:

       kill -9 spid;

      --spid为第一步中查出来的系统进程号

      经过以上操作之后重新对之前锁定的对象进行操作应该就可以了。

二、使用了相关表的基本介绍

  • V$LOCKED_OBJECT中的列说明:

    XIDUSN:回滚段号

    XIDSLOT:槽号

    XIDSQN:序列号

    OBJECT_ID:被锁对象ID

    SESSION_ID:持有锁的sessionID

    ORACLE_USERNAME:持有锁的Oracle 用户名

    OS_USER_NAME:持有锁的操作系统 用户名

    PROCESS:操作系统进程号

    LOCKED_MODE:锁模式

  • dba_objects的列说明

    OWNER

              Username of the owner of the object

        OBJECT_NAME

              Name of the object

        SUBOBJECT_NAME

              Name of the sub-object (for example,partititon)

        OBJECT_ID

              Object number of the object

        DATA_OBJECT_ID

              Object number of the segment which contains the object

        OBJECT_TYPE

              Type of the object

        CREATED

              Timestamp for the creation of the object

        LAST_DDL_TIME

              Timestamp for the last DDL change (including GRANT and REVOKE) to the object

        TIMESTAMP

              Timestamp for the specification of the object

        STATUS

              Status of the object

        TEMPORARY

              Can the current session only see data that it place in this object itself?

        GENERATED

              Was the name of this object system generated?

        SECONDARY

              Is this a secondary object created as part of icreate for domain indexes?

  • v$session的说明

    V$SESSION是基础信息视图,用于找寻用户SID或SADDR

    常用列:

    SID:SESSION标识

    SERIAL#:如果某个SID又被其它的session使用的话则此数值自增加(当一个SESSION结束,另一个SESSION开始并使用了同一个SID)。

    AUDSID:审查session ID唯一性,确认它通常也用于当寻找并行查询模式

    USERNAME:当前session在oracle中的用户名。

    STATUS:这列用来判断session状态是:

        Achtive:正执行SQL语句(waiting for/using a resource)

        Inactive:等待操作(即等待需要执行的SQL语句)

        Killed:被标注为删除

  • v$process视图

    v$process视图包含当前系统Oracle运行的所有进程信息。常被用于将Oracle或服务进程的操作系统进程ID与数据库session之间建立联系。

    常用列:

    ADDR:进程对象地址

    PID:oracle进程ID

    SPID:操作系统进程ID

<think>嗯,用户想了解Oracle的相关内容。首先,我需要确认用户所说的“”具体指的是什么。在Oracle数据库中,通常发生在多个会话同时访问同一资源时,比如一个会话正在执行DML操作(如UPDATE、DELETE),而另一个会话试图修改同一数据或执行DDL操作,这时候可能会发生冲突。 接下来,我应该分步骤解释如何识别和处理。首先,用户需要确定哪个会话持有,哪个会话在等待。这可以通过查询数据字典视图如DBA_BLOCKERS、DBA_WAITERS,或者使用v$session和v$lock视图来实现。可能还需要提到DBA_DDL_LOCKS之类的视图,但需要确保准确性。 然后,处理方法通常包括提交或回滚持有的会话,或者强制终止会话。需要详细说明如何找到相关的SID和SERIAL#,以及使用ALTER SYSTEM KILL SESSION命令。同时,要提醒用户谨慎使用强制终止,因为这可能导致数据不一致或其他问题。 另外,用户可能还关心如何预防的问题,比如优化事务设计,减少持有时间,使用适当的隔离级别等。这部分内容对用户来说也很重要,可以帮助他们避免未来出现类似问题。 需要注意的是,用户可能对某些术语不太熟悉,比如会话、SID、SERIAL#等,可能需要用更易懂的语言解释。同时,示例代码的正确性很重要,比如查询语句是否正确,命令是否有语法错误。需要确保提供的SQL命令在Oracle环境中有效,比如连接正确的视图和列名。 还要考虑用户的使用场景,可能是开发人员或DBA,所以需要提供不同层面的解决方案。如果是开发人员,可能需要指导他们检查应用程序中的事务逻辑;如果是DBA,可能需要更直接的解步骤。 最后,要确保整个回答结构清晰,步骤明确,用户能够按照指引逐步解决问题。同时,提醒用户在生产环境中谨慎操作,尤其是在终止会话时,避免影响其他正在进行的操作。</think>### Oracle操作指南 #### 一、定的常见场景 当发生以下情况时可能触发: - 长时间未提交的DML操作(UPDATE/DELETE) - 并行会话尝试修改相同数据 - DDL操作(ALTER TABLE)与DML操作冲突 - 事务异常中断未释放 #### 二、定检测步骤 1. **查询信息** ```sql SELECT s.sid, s.serial#, s.username, s.machine, l.type lock_type, o.object_name FROM v$locked_object lo JOIN dba_objects o ON lo.object_id = o.object_id JOIN v$session s ON lo.session_id = s.sid WHERE o.object_name = '你的名'; ``` 2. **查看阻塞关系** ```sql SELECT blocker.sid blocker_sid, waiter.sid waiter_sid, blocker.sql_id blocker_sql FROM v$session blocker, v$session waiter WHERE waiter.blocking_session = blocker.sid; ``` #### 三、解解决方案 1. **正常释放** ```sql -- 提交事务(由持有的会话执行) COMMIT; -- 回滚事务(由持有的会话执行) ROLLBACK; ``` 2. **强制解(需DBA权限)** ```sql -- 终止会话(替换实际查到的sid和serial#) ALTER SYSTEM KILL SESSION 'sid,serial#' IMMEDIATE; -- 强制断开连接(Oracle 12c+) ALTER SYSTEM DISCONNECT SESSION 'sid,serial#' POST_TRANSACTION; ``` 3. **系统级清除(极端情况)** ```sql -- 重启数据库(需停机) SHUTDOWN IMMEDIATE; STARTUP; ``` #### 四、预防措施 1. **事务优化** - 保持事务短小精悍 - 避免在事务中执行长时间操作 - 使用`SELECT ... FOR UPDATE NOWAIT` 2. **监控配置** ```sql -- 设置超时(单位:秒) ALTER SYSTEM SET ddl_lock_timeout = 30; ``` 3. **开发规范** - DDL操作前检查使用状态 - 使用`DBMS_LOCK`包管理自定义 - 定期分析`AWR`报告中的事件 #### 五、注意事项 1. 强制kill会话可能导致: - 未提交事务回滚 - 临时对象泄漏 - 应用程序连接异常 2. 建议优先联系持有的用户协商解决 3. 对关键业务操作建议在维护窗口进行 > 建议结合`ASH`(Active Session History)和`ADDM`(Automatic Database Diagnostic Monitor)进行深度分析。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值