注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

还东国的博客

行之苟有恒,久久自芬芳

 
 
 

日志

 
 

简述数据库的锁  

2014-08-21 16:00:15|  分类: 数据库技术 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

简述数据库的锁

在数据库中,一般来说为了防止数据的并发访问,会设置式各样的锁,但不管怎么来看,总体上就两种:排他锁(X锁)和共享锁(S锁)。如果按锁的粒度大小分,又可以分为表锁和行级锁。

ORACLE数据库中又可以分成:Oracle数据库锁可以分为以下几大类:

DML(data locks,数据锁),用于保护数据的完整性;

DDL(dictionary locks,字典锁),用于保护数据库对象的结构,如表、索引等的结构定义;

内部锁和闩(internal locks and latches),保护数据库的内部结构,应用于SGA;

DML锁的目的在于保证并发情况下的数据完整性,主要包括TM锁和TX锁,其中TM锁称为表级锁,TX锁称为事务锁或行级锁。

其实不管怎么划分,其目的都是一样的。保护数据的完整性和一致性。

另外就得提一下意向锁:

意向锁包括意向共享 (IS)、意向排它 (IX) 以及与意向排它共享 (SIX)

意向共享 (IS) 通过在各资源上放置 S 锁,表明事务的意向是读取层次结构中的部分(而不是全部)底层资源。

意向排它 (IX) 通过在各资源上放置 X 锁,表明事务的意向是修改层次结构中的部分(而不是全部)底层资源。IX IS 的超集。

与意向排它共享 (SIX) 通过在各资源上放置 IX 锁,表明事务的意向是读取层次结构中的全部底层资源并修改部分(而不是全部)底层资源。允许顶层资源上的并发 IS 锁。例如,表的 SIX 锁在表上放置一个 SIX 锁(允许并发 IS 锁),在当前所修改页上放置 IX 锁(在已修改行上放置 X 锁)。虽然每个资源在一段时间内只能有一个 SIX 锁,以防止其它事务对资源进行更新,但是其它事务可以通过获取表级的 IS 锁来读取层次结构中的底层资源。

意向锁其实就是为了提高效率看一看是不是可以加各种锁,就好像你想和朋友做什么事说什么话,提前打个招呼看人家有没有时间,能不能去一样。

更多的锁的资料请大家翻阅数据库相关的书籍和资料,这个非常多。设计和优化数据库,这个是必不可少的知识。

  评论这张
 
阅读(401)| 评论(0)
推荐 转载

历史上的今天

在LOFTER的更多文章

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2017