zoukankan      html  css  js  c++  java
  • Oracle死锁处理

    死锁是数据库经常发生的问题,数据库一般不会无缘无故产生死锁,死锁通常都是由于我们应用程序的设计本身造成的。产生死锁时,如何解决呢,下面是常规的解决办法:

    1)执行下面SQL,先查看哪些表被锁住了:
    select b.owner,b.object_name,a.session_id,a.locked_mode
    from v$locked_object a,dba_objects b
    where b.object_id = a.object_id;

    2)查处引起死锁的会话
    select b.username,b.sid,b.serial#,logon_time
    from v$locked_object a,v$session b
    where a.session_id = b.sid order by b.logon_time;
    这里会列出SID

    #查询死锁#
    select b.owner,b.object_name,c.username,c.sid,c.serial#,c.logon_time,a.locked_mode
    from v$locked_object a,dba_objects b,v$session c
    where b.object_id = a.object_id and a.session_id = c.sid
    order by c.logon_time;

    3) 查出SID和SERIAL#:
    查V$SESSION视图:
    SELECT SID,SERIAL#,PADDR FROM V$SESSION WHERE SID='刚才查到的SID';
    这一步将得到PADDR

    4)查V$PROCESS视图:
    SELECT SPID FROM V$PROCESS WHERE ADDR='刚才查到的PADDR';
    这一步得到SPID

    5)杀死进程
    (1)在数据库中,杀掉ORACLE进程:
    ALTER SYSTEM KILL SESSION '查出的SID,查出的SERIAL#';

    (2)如果在ORACLE中不能杀死进程,我们只能到操作系统中,使用操作系统命令杀死进程
    KILL -9  “刚才查出的SPID”

  • 相关阅读:
    spark sql 性能调优
    google c++ 规范
    idea
    Ubuntu16.04-hadoop3 安装与配置
    NewRelic 性能监测工具
    关于 g++ link
    vue 实现 多个 数字滚动增加动效
    mac 电脑安装express、npm…… 报 ‘Missing write access to /usr/local/lib/node_modules’错误解决办法
    vue + mock.js 简单使用
    vue去掉地址栏# 方法
  • 原文地址:https://www.cnblogs.com/xgw2004058/p/2761947.html
Copyright © 2011-2022 走看看