oracle表锁住 解锁办法

第一种方法:

用系统账户如sys      as  SYSDBA 登录进去

1、查看数据库锁,诊断锁的来源及类型: 
select object_id,session_id,locked_mode from v$locked_object; 
或者用以下命令: 
select b.owner,b.object_name,l.session_id,l.locked_mode 
from v$locked_object l, dba_objects b 
where b.object_id=l.object_id 
2、找出数据库的serial#,以备杀死: 
select t2.username,t2.sid,t2.serial#,t2.logon_time 
from v$locked_object t1,v$session t2 
where t1.session_id=t2.sid order by t2.logon_time; 
3、杀死该session 
alter system kill session ‘sid,serial#‘

第二种方法:

慢慢等待,据说oracle也会把该进程杀死

oracle表锁住 解锁办法,布布扣,bubuko.com

时间: 2024-10-10 15:36:45

oracle表锁住 解锁办法的相关文章

Oracle 表锁住,杀掉锁表进程

背景 在操作Oracle时,多人同时操作oracle数据库的同一张表的时候,经常会造成锁表现象,这时需要手动进行解锁. 步骤 以dba身份登录Oracle数据库(否则用户缺少杀掉进程权限,需要给用户分配权限) sqlplus  /  as sysdba,如下图 查看被锁住的表进程 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 表空间不足解决办法

Oracle表空间不足,一般有两个原因: 1. 原表空间太小,没有自增长: 2. 表空间已自增长,而且表空间也已足够大 检查原因: 1. 查看表在那个表空间 select tablespace_name,table_name from user_talbes where table_name='test'; 2. 获取用户的默认表空间 select username, DEFAULT_TABLESPACE from dba_users where username='MXH'; 3. 查看表空间

oracle数据库锁表

在团队开发一个项目的时候,避免不了两个或两个以上的人同时操作某一数据库中的同一张表,这时候,如果一个用户没有提交事务,或者忘记提交事务,那么其他用户就不能对这张表进行操作了,这是很烦人的事情,下面是查询是哪个用户将表锁住了,并且生成解表语句的sql: Select O.OWNER, O.OBJECT_NAME, O.OBJECT_TYPE, (SELECT C.MACHINE FROM V$SESSION C WHERE C.SID = S.SID), (SELECT C.PROGRAM FRO

mysql 表锁-解锁

遇到问题"" 用工具navicat打开一张表的时候,有的时候会发现这张表怎么打不开,关了navicat工具,再打开,也是同样的状态. 查看表锁: show OPEN TABLES where In_use > 0; 查看是否是表锁住了. -- 查看进程号 show processlist; 这样就是表锁了, | 10664505 | root | ip:port | tables           | Query   |  5074  | Waiting for table m

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.查看引起表锁住的Session select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_i

oracle 表被另一个用户锁住后的解决办法

oracle 表被另一个用户锁住后的解决办法 1.查看数据库锁,诊断锁的来源及类型: select object_id,session_id,locked_mode from v$locked_object; 2.找出数据库的serial#,以备杀死: select t2.username,t2.sid,t2.serial#,t2.logon_time from v$locked_object t1,v$session t2 where t1.session_id=t2.sid order by

Oracle锁表查询和解锁方法

数据库操作语句的分类 DDL:数据库模式定义语言,关键字:create DML:数据操纵语言,关键字:Insert.delete.update DCL:数据库控制语言 ,关键字:grant.remove DQL:数据库查询语言,关键字:select oracle表在什么情况下会被锁住 DML锁又可以分为,行锁.表锁.死锁 行锁:当事务执行数据库插入.更新.删除操作时,该事务自动获得操作表中操作行的排它锁. 表级锁:当事务获得行锁后,此事务也将自动获得该行的表锁(共享锁),以防止其它事务进行DDL

Oracle的锁表与解锁

Oracle的锁表与解锁 SELECT /*+ rule */ s.username, decode(l.type,'TM','TABLE LOCK', 'TX','ROW LOCK', NULL) LOCK_LEVEL, o.owner,o.object_name,o.object_type, s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser FROM v$session s,v$lock l,dba_objects o WHERE

oracle数据库表被锁的解锁方法

亲测可用 Oracle数据库操作中,我们有时会用到锁表查询以及解锁和kill进程等操作,那么这些操作是怎么实现的呢?本文我们主要就介绍一下这部分内容.(1)锁表查询的代码有以下的形式:select count(*) from v$locked_object;select * from v$locked_object;(2)查看哪个表被锁select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,db