【YashanDB数据库】YAS-02024 lock wait timeout, wait time 0 milliseconds

【标题】错误码处理

【问题分类】锁等待超时

【关键字】YAS-02024

【问题描述】执行语句时候,因锁等待超时执行语句失败

【问题原因分析】数据库默认锁等待时间为0秒,如果执行语句存在锁等待过长会执行失败

【解决/规避方法】

调整锁等待的时间

alter system set DDL_LOCK_TIMEOUT = x;
单位是s, 默认是0, 修改为300
确认持久化到config/yasdb.ini文件

找出导致锁等待的session ,并根据实际情况确认能不能先使其退出

v$lock确定sid

select * from v$lock;

再关联dv$session确定serial

select * from v$session;

再执行alter system kill session 命令kill引起锁超时的会话

alter system kill session '30,918';

如果会话比较多,可以使用如下语句批量杀死线程

select 'ALTER SYSTEM kill SESSION '''||SID||','||SERIAL# || '''' || ';' from v$session t1, v$locked_object t2 where t1.sid = t2.SESSION_ID

–查询哪些表锁死 记录下SID和serial#

杀掉对应的会话进程

【影响范围】所有版本

【修复版本】无

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值