ORACLE 锁的概念

 

转载:ORACLE 锁的概念

ORACLE 的概念
作者: tonnyluo·yesky 出处:皇家数据库技术

ORACLE数据库是现今数据库领域应用最广泛的,同时它也是一个庞大的系统,全面了解它、玩转它不但需要一定的理论知识,更需要开发经验与工程经验。本人是ORACLE一爱好者,以下是本人对ORACLE的一些经验,希望能与大家共同分享。
预备知识:
DDL(DATABASE DEFINITION LANGUAGE):数据库定义语言,如create table、drop table.....
DML(DATABASE MODIFICATION LANGUAGE):数据库修改语言,如insert、delete、update......
参考资料:Oracle8 Administrator"s Guide, Release 8.0
      Oracle8 Tuning, Release 8.0

ORACLE具体分为以下几类:
1.按用户与系统划分,可以分为自动与显示
自动:当进行一项数据库操作时,缺省情况下,系统自动为此数据库操作获得所有有必要的
显示:某些情况下,需要用户显示的定数据库操作要用到的数据,才能使数据库操作执行得更好,显示是用户为数据库对象设定的。
2.按级别划分,可分为共享与排它
共享:共享使一个事务对特定数据库资源进行共享访问——另一事务也可对此资源进行访问(增删改吗?DDL是不是被禁止?)或获得相同共享。共享为事务提供高并发性,但如拙劣的事务设计+共享容易造成死或数据更新丢失。
排它:事务设置排它后,该事务单独获得此资源,另一事务不能在此事务提交之前获得相同对象的共享或排它
3.按操作划分,可分为DML、DDL
+DML又可以分为,行、表、死
-行:当事务执行数据库插入、更新、删除操作时,该事务自动获得操作表中操作行的排它
-表级:当事务获得行后,此事务也将自动获得该行的表(共享),以防止其它事务进行DDL语句影响记录行的更新。事务也可以在进行过程中获得共享或排它,只有当事务显示使用LOCK TABLE语句显示的定义一个排它时,事务才会获得表上的排它,也可使用LOCK TABLE显示的定义一个表级的共享(LOCK TABLE具体用法请参考相关文档)。
【LOCK TABLE用来定整个表,定可分为共享模式或者独占模式,共享模式可以防止其他会话获得独占定,但是允许其他会话获得一个共享定,独占模式则即防止其他会话获取共享定,又防止其他会话获得独占定】
-死:当两个事务需要一组有冲突的,而不能将事务继续下去的话,就出现死。如事务1在表A行记录#3中有一排它,并等待事务2在表A中记录#4中排它的释放,而事务2在表A记录行#4中有一排它,并等待事务1在表A中记录#3中排它的释放,事务1与事务2彼此等待,因此就造成了死。死一般是因拙劣的事务设计而产生。
只能使用SQL下:alter system kill session "sid,serial#";或者使用相关操作系统kill进程的命令,如UNIX下kill -9 sid,或者使用其它工具杀掉死进程。
+DDL又可以分为:排它DDL、共享DDL、分析
-排它DDL:创建、修改、删除一个数据库对象的DDL语句获得操作对象的 排它。如使用alter table语句时,为了维护数据的完成性、一致性、合法性,该事务获得一排它DDL
-共享DDL:需在数据库对象之间建立相互依赖关系的DDL语句通常需共享获得DDL。如创建一个包,该包中的过程与函数引用了不同的数据库表,当编译此包时,该事务就获得了引用表的共享DDL
-分析:ORACLE使用共享池存储分析与优化过的SQL语句及PL/SQL程序,使运行相同语句的应用速度更快。一个在共享池中缓存的对象获得它所引用数据库对象的分析。分析是一种独特的DDL类型,ORACLE使用它追踪共享池对象及它所引用数据库对象之间的依赖关系。当一个事务修改或删除了共享池持有分析的数据库对象时,ORACLE使共享池中的对象作废,下次在引用这条SQL/PLSQL语句时,ORACLE重新分析编译此语句。
4.内部闩
内部闩:这是ORACLE中的一种特殊,用于顺序访问内部系统结构。当事务需向缓冲区写入信息时,为了使用此块内存区域,ORACLE首先必须取得这块内存区域的闩,才能向此块内存写入信息。

 

ORACLE锁的管理

ORACLE里有以下几种模式:
0:none
1:null 空
2:Row-S 行共享(RS):共享表,sub share
3:Row-X 行独占(RX):用于行的修改,sub exclusive
4:Share 共享(S):阻止其他DML操作,share
5:S/Row-X 共享行独占(SRX):阻止其他事务操作,share/sub exclusive
6:exclusive 独占(X):独立访问使用,exclusive

数字越大级别越高, 影响的操作越多。

1级有:Select,有时会在v$locked_object出现。
2级有:Select for update,Lock For Update,Lock Row Share
select for update当对话使用for update子串打开一个游标时,所有返回集中的数据行都将处于行级(Row-X)独占式定,其他对象只能查询这些数据行,不能进行update、delete或select for update操作。
3级有:Insert, Update, Delete, Lock Row Exclusive
没有commit之前插入同样的一条记录会没有反应, 因为后一个3的会一直等待上一个3的, 我们必须释放掉上一个才能继续工作。
4级有:Create Index, Lock Share
locked_mode为2,3,4不影响DML(insert,delete,update,select)操作, 但DDL(alter,drop等)操作会提示ora-00054错误。
00054, 00000, "resource busy and acquire with NOWAIT specified"
// *Cause: Resource interested is busy.
// *Action: Retry if necessary.
5级有:Lock Share Row Exclusive
具体来讲有主外键约束时update / delete ... ; 可能会产生4,5的
6级有:Alter table, Drop table, Drop Index, Truncate table, Lock Exclusive

以DBA角色, 查看当前数据库里的情况可以用如下SQL语句:
col owner for a12
col object_name for a16
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
/

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
/

如果有长期出现的一列,可能是没有释放的。我们可以用下面SQL语句杀掉长期没有释放非正常的:alter system kill session 'sid,serial#';
如果出现了的问题, 某个DML操作可能等待很久没有反应。
当你采用的是直接连接数据库的方式,也不要用OS系统命令 $kill process_num 或者 $kill -9 process_num来终止用户连接,因为一个用户进程可能产生一个以上的, 杀OS进程并不能彻底清除的问题。
 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/17252115/viewspace-741082/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/17252115/viewspace-741082/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值