达梦数据库修改表失败 错误号: -6407 批量删除锁超时会话id

问题描述:通过sql修改某张表时,报错锁超时,如下图所示
达梦数据库修改表失败 错误号: -6407 批量删除锁超时会话id_第1张图片
问题解决:先通过以下sql语句确定该表是否在会话中存在表锁

select a.*,b.NAME,c.SESS_ID from v$lock a  left join sysobjects b on b.ID=a.TABLE_ID left join v$sessions c on a.TRX_ID=c.TRX_ID;

执行完sql如下图所示,通过name可以确定与该表相关的sess_id有哪些。达梦数据库修改表失败 错误号: -6407 批量删除锁超时会话id_第2张图片
如果sess_id不多,我们可以通过执行以下sql语句解除表锁

sp_close_session(sess_id)

注意sql_close_session只能接收一个参数,如果相关sess_id有成百上千个,我们就需要先对这些sess_id进行处理,执行下面sql语句先把这些相关sess_id查询出来并把结果整到一个word文档中

select c.SESS_ID from v$lock a  left join sysobjects b on b.ID=a.TABLE_ID left join v$sessions c on a.TRX_ID=c.TRX_ID  where b.name='表名'

对数据进行查找替换,替换完后把第一条和最后一条数据再进行下手动处理
达梦数据库修改表失败 错误号: -6407 批量删除锁超时会话id_第3张图片
最后,将处理好的语句直接粘贴到数据库中进行执行即可
达梦数据库修改表失败 错误号: -6407 批量删除锁超时会话id_第4张图片

你可能感兴趣的:(数据库,sql,database)