YashanDB · 7月12日

【YashanDB知识库】YAS-02024 lock wait timeout, wait tim

【标题】错误码处理

【问题分类】锁等待超时

【关键字】YAS-02024

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

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

【解决/规避方法】

1、调整锁等待的时间

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

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

  • .查dv$lock确定sid

    SQL
    select * from v$lock;
  • 再关联dv$session确定serial

    SQL
    alter system kill session '30,918';
  • 再执行alter system kill session 命令kill引起锁超时的会话

    Shell
    SQLSTATE[HY000]:General error:202 [YashanDB][ODBC Driver][Yas][YAS-00202]invalid string,reason:invalid indicator value
  • 如果会话比较多,可以使用如下语句批量杀死线程

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

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

杀掉对应的会话进程

【影响范围】所有版本

【修复版本】无

推荐阅读
关注数
1
文章数
36
目录
极术微信服务号
关注极术微信号
实时接收点赞提醒和评论通知
安谋科技学堂公众号
关注安谋科技学堂
实时获取安谋科技及 Arm 教学资源
安谋科技招聘公众号
关注安谋科技招聘
实时获取安谋科技中国职位信息