解决Oracle锁表

概述:
锁表是很容易发生的现象,当有多人对表进行操作时就容易发生。如下是解决锁表的步骤

锁表原因:
由于Oracle数据库具有保持数据的一致性,所以当一个人对表进行操作,没有提交,另一个人在需要操作的时候,就不能操作,必须等表提交,就一直处于等待状态,就导致锁表。

锁表报错信息:   
如果发现修改一个表数据时不能提交而报下面的错误:
Record is locked by another user

解决方法:   
杀死会话进程或者再执行sql语句,然后提交。

解决步骤:
1. 登陆数据库,以sys用户登陆
SQL> conn /as sysdba
Connected.
SQL>
SQL>
SQL>
2. 查询哪些会话被锁。
SQL> 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;

USERNAME                              SID    SERIAL LOGON_TIME
------------------------------ ---------- ---------- -------------------
IPMS                                  494      10320 2014-01-23 08:03:38
IPMS                                  479      25009 2014-01-23 08:04:50
HCBA                                  401      59957 2014-01-23 08:43:23

SQL>
SQL>
SQL>
2.1. 查看会话具体内容
SQL> select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=&sid order by piece;
Enter value for sid: 494  ------     (在此输入sid号)
old   1: select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=&sid order by piece
new   1: select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=494 order by piece

SQL_TEXT
----------------------------------------------------------------
UPDATE IPMS.IS_STANDARD D  SET D.IS_LOCKCOUNT = D.IS_LOCKCOUNT -

(SELECT SUM(M.IM_APPLYNUM)

FROM IS_MATERIALAPPLY M

WHERE M.IM_GBID IN
                                (SELECT

SQL_TEXT
----------------------------------------------------------------
G.IGB_ID
                                   FROM IPMS.IS_GRANTB

ILL G  INNER JOIN IPMS.WWF_INSTANCE I ON G.IGB_FLOWID =  I.INSTA
NCE_ID
                                  WHERE I.INSTANCE_ID=:I

NSTANCE_ID)
                            AND D.IM_ID = M.IM_ID

AND D.IS_LOCK = 1

SQL_TEXT
----------------------------------------------------------------

)

10 rows selected.
2.2 查询会话具体内容
SQL> select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=&sid order by piece;
Enter value for sid: 479(在此输入sid号)
old   1: select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=&sid order by piece
new   1: select sql_text from v$session a,v$sqltext_with_newlines b where decode(a.sql_hash_value,0,prev_hash_value,sql_hash_value)=b.hash_value and a.sid=479 order by piece

SQL_TEXT
----------------------------------------------------------------
begin
  sys.dbms_output.get_line(line => :line, status => :statu

s);
end;

3. 杀死该会话
根据刚才查询出来的sid号和serial值。

SQL>
SQL> alter system kill session ‘494,10320‘;

System altered.

SQL> alter system kill session ‘479,25009‘;

System altered.

SQL> commit;

Commit complete.

SQL>

时间: 2024-10-13 10:15:34

解决Oracle锁表的相关文章

查询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,dba_obj

oracle 锁表 及 解锁

很久没有写博客了.不知道写什么 今天,让我清一张表的数据,结果清了之后,系统直接不动了,就好像服务器挂死了一样. 后来找了半天才发现,原来是我删除数据之后没有提交事物造成了数据库锁表,然后又不明白了, 什么是锁表呢,于是就上网去查 查了半天,大多数都是说怎么解决锁表和查询锁表的,但是只了解方法还不够,又想知道原理,于是 就继续往深里查查到了oracle的锁机制 由于数据库是多用户同时使用的共享资源,当多个用户并发的存取事物的时候,数据库中就会发生多个进程 同时操作同一个数据的情况,若对并发操作不

Oracle锁表查询和解锁方法

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

Oracle锁表 行级锁 表级锁 行级锁

Oracle锁表  行级锁  表级锁 ---- 行被排他锁定 ----在某行的锁被释放之前,其他用户不能修改此行          ----使用 commit 或 rollback 命令释放锁 ----Oracle 通过使用 INSERT.UPDATE 和 SELECT-FOR UPDATE 语句自动获取行级锁 SELECT-FOR UPDATE 子句  ―在表的一行或多行上放置排他锁  ―用于防止其他用户更新该行 ―可以执行除更新之外的其他操作 ―select * from goods whe

oracle锁表

Oracle锁表比较简单,查询锁表的session杀掉就可以了. 1.以下几个为相关表 SELECT * FROM V$LOCK; SELECT * FROM V$SQLAREA; SELECT * FROM V$SESSION; SELECT * FROM V$PROCESS; SELECT * FROM V$LOCKED_OBJECT; SELECT * FROM ALL_OBJECTS; SELECT * FROM V$SESSION_WAIT; 2.查看被锁的表 SELECT B.OWN

解决ora-00054 Oracle锁表问题

1.运行sql: select session_id from v$locked_object;   查出锁表的session,可能很多,正常是没有的 2.SELECT sid, serial#, username, osuser FROM v$session where sid = 162;   将162换成你查出来的session_id 3.kill掉session ALTER SYSTEM KILL SESSION '162,4294';   4294为第二步查出来的serial#; 转自

Oracle 锁表查询及解锁

如果对 Oracle 数据表中的数据进行 增删改 操作时卡住无响应,很可能是表已被锁定.使用下面的命令可以解决锁定问题. 锁表状态查询. 直接复制粘贴就可以. --锁表查询SQL SELECT object_name, machine, s.sid, s.serial#  FROM gv$locked_object l, dba_objects o, gv$session s  WHERE l.object_id = o.object_id  AND l.session_id = s.sid;

Oracle锁表故障处理一例

一次开发人员直接在数据库服务器上做delete table操作系统,由时在上班高峰运行,造成长时间执行无反应,进而把SQLPLUS客户端关闭掉,再次运行删除语句,造成数据库运行缓慢.   询问操作过程知道了是由锁表造成,最终处理:本文只是模拟锁表处理过程,下次遇到相同问题可以快速处理. 1. 查看数据库的等待事件 如果不清楚原因,可以通过先通过等待事件进行分析. SQL> select sid,EVENT from v$session_wait where wait_class<>'Id

Oracle锁表及解锁

为了防止用户在同一时间并发地访问和修改资源,ORACLE使用不同类型的锁控制对数据的并发访问,以防止用户之间出现破坏性的交互操作 1,锁表 锁定表的通用语法: lock table 表名 in <share or share update or exclusive mode> 共有三种锁表模式: 共享模式(in share mode) 共享更新模式(in share update mode) 排他锁模式(in exclusive mode) 锁表实例: //以排他锁模式锁定tRun表 lock