• 技术文章 > mysql教程

    oracle查看被锁的表以及解锁的方法介绍(代码示例)

    不言 不言 2019-02-12 11:47:06 转载 78
    本篇文章给大家带来的内容是关于oracle查看被锁的表以及解锁的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    --以下几个为相关表

    SELECT * FROM v$lock;
    SELECT * FROM v$sqlarea;
    SELECT * FROM v$session;
    SELECT * FROM v$process ;
    SELECT * FROM v$locked_object;
    SELECT * FROM all_objects;
    SELECT * FROM v$session_wait;

    --查看被锁的表

    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;

    --查看那个用户那个进程照成死锁

    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;

    --查看连接的进程

    SELECT sid, serial#, username, osuser FROM v$session;

    --3.查出锁定表的sid, serial#,os_user_name, machine_name, terminal,锁的type,mode

    SELECT s.sid, s.serial#, s.username, s.schemaname, s.osuser, s.process, s.machine,
    s.terminal, s.logon_time, l.type
    FROM v$session s, v$lock l
    WHERE s.sid = l.sid
    AND s.username IS NOT NULL
    ORDER BY sid;

    这个语句将查找到数据库中所有的DML语句产生的锁,还可以发现,
    任何DML语句其实产生了两个锁,一个是表锁,一个是行锁。

    --杀掉进程 sid,serial#

    alter system kill session '210,11562'; 此处不能连接起来 要有空格,不然会报错的例如(alter system kill session'210,11562'; )

    以上就是oracle查看被锁的表以及解锁的方法介绍(代码示例)的详细内容,更多请关注php中文网其它相关文章!

    第五期线上培训班
    专题推荐: oracle
    上一篇:MapReduce的基本内容介绍(附代码) 下一篇:SqlServer中五个系统数据库的简单介绍

    相关文章推荐

    • JavaScript操作Oracle数据库示例_javascript技巧 • 查找Oracle高消耗语句的方法_javascript技巧 • PHP实现的oracle分页函数实例_php技巧 • php连接oracle数据库及查询数据的方法_php技巧

    全部评论我要评论

  • 取消 发布评论 发送
  • PHP中文网