oracle数据库锁表解决办法
发布时间:2020-12-12 13:34:44 所属栏目:百科 来源:网络整理
导读:当多人同时操作oracle数据库的同一张表的时候,经常会造成锁表现象,这时需要手动进行解锁。 首先:先看下那些表被锁住,程序如下: 1, select b.owner,b. object_name ,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b. object_i
当多人同时操作oracle数据库的同一张表的时候,经常会造成锁表现象,这时需要手动进行解锁。 首先:先看下那些表被锁住,程序如下: 1, select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id; 2, select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time; 然后:杀死进程中的会话,程序如下: alter system kill session ‘sid,serial#‘; //举例: alter system kill session ‘29,5497‘; //其中29指第一条sql中sid列内容,5497指第二条sql中serial#列内容 ? 其他解决办法: 删除会话需要有DBA权限,使用sys账号或者system账号 如果忘记了这两个账号密码,需要等到session过期。生产环境是之前离职的同事部署的,账号密码也已经忘了。 查询的时候session登陆时间是早上9点28分,我在中午12点的时候查询的时候session已经过期了,表已经解锁。session过期时间大概在2到3个小时左右。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |