炫“库”行动-人大金仓有奖征文-KingbaseESV8R3表锁处理

【本文正在参与炫“库”行动-人大金仓有奖征文】

https://marketing.csdn.net/p/98bd30353e7cb998b6070a89e8b91edb

注:kill锁方式

kill有第一种方式:
SELECT sys_cancel_backend(PID) from sys_stat_activity where state like '%idle in transaction%';
这种方式只能kill select查询,对update、delete 及DML不生效)

第二种方式:
SELECT sys_terminate_backend(PID) from sys_stat_activity where state like '%idle in transaction%';
这种可以kill掉各种操作(select、update、delete、drop等)操作

【生产环境建议:和业务人员沟通确定是否可以kill释放锁并回退,明确处理影响】


一.查询是否锁表及处理表锁

1.找到表对应的oid

select oid  from sys_locks where granted='f';

2.根据oid找到表名
select relname from sys_class where oid='上述oid';

3.根据oid找到表名
select pid from sys_locks where relation='上面查出的oid'

3.如果查询到了结果,表示该表被锁 则需要释放锁定
select sys_cancel_backend(上面查到的pid);

或者对首次给表加锁的会话整库批量kill

SELECT sys_terminate_backend(PID) from sys_stat_activity where state like '%idle in transaction%';

二.定位锁表具体操作
 

1.找到表对应的oid

select oid  from sys_locks where granted='f';

2.根据oid找到表名
select relname from sys_class where oid='上述oid';

3.根据oid找到表名
select pid from sys_locks where relation='上面查出的oid'

4.查看数据库首次对表加的具体操作信息。select now()-query_start wait , pid,query,state from sys_stat_activity where  and query like '%相关表名%' state like '%idle in transaction%'  order by wait;

【本文正在参与炫“库”行动-人大金仓有奖征文】

https://marketing.csdn.net/p/98bd30353e7cb998b6070a89e8b91edb

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值