您现在的位置是:群英 > 数据库 > 关系型数据库
Oracle锁表查询怎么做,对锁表处理操作是怎样
Admin发表于 2022-07-13 17:20:58844 次浏览
今天就跟大家聊聊有关“Oracle锁表查询怎么做,对锁表处理操作是怎样”的内容,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

废话不多说 上语句:

查询锁表语句:

select object_name,machine,s.sid,s.serial#
 
from v$locked_object l,dba_objects o ,v$session s
 
where l.object_id = o.object_id and l.session_id=s.sid;

杀掉查到的进程:

alter system kill session 'sid,serial#';
 
例如:
 
alter system kill session '20,182';

如果杀不掉可以加个 immediate  立即杀掉 试试;

alter system kill session '20,182' immediate;

如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:

select spid, osuser, s.program 
from v$session s,v$process p
where s.paddr=p.addr and s.sid=20 --24 为上面的sid

windows :

orakill  sid   spid --sid 数据库实例名  spid 线程id

linux:

KILL -9 SPID -- 查到的线程id

杀了这个进程感觉舒服多了,如果是我们自己玩没什么 ,可要是在生产环境你就要小心了 所以我们需要注意一下了

--(1)锁表查询的代码有以下的形式:
select count(*) from v$locked_object;
select * from v$locked_object;
--(2)查看哪个表被锁
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;
--(3)查看是哪个session引起的
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;
--(4)查看是哪个sql引起的
select b.username,b.sid,b.serial#,c.* from v$locked_object a,v$session b,v$sql c where a.session_id = b.sid
and b.SQL_ID = c.sql_id and c.sql_id = ''
order by b.logon_time;

至此这篇就结束了。


通过以上内容的阐述,相信大家对“Oracle锁表查询怎么做,对锁表处理操作是怎样”已经有了进一步的了解,更多相关的问题,欢迎关注群英网络或到群英官网咨询客服。

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

标签: oracle锁表查询
相关信息推荐
2022-09-14 17:55:06 
摘要:本篇文章给大家带来了关于mysql日志的相关知识,我们重点需要关注的是二进制日志(binlog)和事务日志(包括redo log和undo log),希望对大家有帮助。
2022-10-18 17:56:03 
摘要:mysql最大连接数怎么设置?下面本篇文章给大家介绍一下mysql设置最大连接数的两种方法,希望对大家有所帮助。
2022-10-21 18:14:40 
摘要:在mysql中,可以利用ALTER TABLE语句配合DROP关键字来删除外键关系(约束),语法“ALTER TABLE 数据表名 DROP FOREIGN KEY 外键约束名;”;“ALTER TABLE”语句用于修改表(改变原有表的结构),而添加了“DROP FOREIGN KEY”语句后,修改功能就限制在删除外键关系(约束)上。
群英网络助力开启安全的云计算之旅
立即注册,领取新人大礼包
  • 联系我们
  • 24小时售后:4006784567
  • 24小时TEL :0668-2555666
  • 售前咨询TEL:400-678-4567

  • 官方微信

    官方微信
Copyright  ©  QY  Network  Company  Ltd. All  Rights  Reserved. 2003-2019  群英网络  版权所有   茂名市群英网络有限公司
增值电信经营许可证 : B1.B2-20140078   粤ICP备09006778号
免费拨打  400-678-4567
免费拨打  400-678-4567 免费拨打 400-678-4567 或 0668-2555555
微信公众号
返回顶部
返回顶部 返回顶部