oracle查看数据被锁及处理

(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)杀掉对应进程

执行命令:alter system kill session'1025,41';
其中1025为sid,41为serial#.
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
处理Oracle中无法杀死的时,首先需要确定的来源和类型。可以通过查询定会话的v$session视图和查看等待资源的v$lock视图来获取相关信息。 一种常见的无法杀死的情况是由于会话在执行事务期间获取了,并且未提交或回滚事务导致的。这种情况下,可以尝试使用ROLLBACK FORCE命令来强制回滚事务,并释放相应的资源。命令语法为:ROLLBACK FORCE 'transaction_id'; 如果被阻塞等待资源的情况较为复杂,可以使用以下步骤处理: 1. 确定导致阻塞的会话和资源:通过查询v$session和v$lock得到阻塞和被阻塞的会话信息。 2. 查找阻塞会话正在等待的资源:通过查询v$lock和v$session获取阻塞会话正在等待的资源。 3. 杀掉阻塞会话:根据阻塞会话的SID和SERIAL#使用ALTER SYSTEM命令来终止会话。命令语法为:ALTER SYSTEM KILL SESSION 'sid,serial#'; 4. 解决被阻塞的会话:解决阻塞会话所等待的资源问题,通过适当的修改表结构、索引、查询语句等方式来优化性能。 5. 重启数据库实例:如果以上方法无法解决问题,可以考虑重启整个数据库实例来清除所有定会话。 需要注意的是,处理问题可能会对数据库的正常运行和数据完整性产生影响,因此在执行任何操作之前,应该先备份数据库,并在非生产环境中进行测试。此外,最好在专业人士的指导下进行操作,以避免不可逆的错误或损坏数据库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值