问题描述:通过sql修改某张表时,报错锁超时,如下图所示
问题解决:先通过以下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有哪些。
如果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='表名'
对数据进行查找替换,替换完后把第一条和最后一条数据再进行下手动处理
最后,将处理好的语句直接粘贴到数据库中进行执行即可