sybase中的锁及死锁问题

sybase中的锁及死锁问题

ID:18285643

大小:61.00 KB

页数:7页

时间:2018-09-16

sybase中的锁及死锁问题_第1页
sybase中的锁及死锁问题_第2页
sybase中的锁及死锁问题_第3页
sybase中的锁及死锁问题_第4页
sybase中的锁及死锁问题_第5页
资源描述:

《sybase中的锁及死锁问题》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、Sybase中的锁及死锁问题一般来说,数据库都会有两种锁:内存锁和对象锁。Oracle中有latch和lock,sybase中有spinlock和lock。内存锁实际上就是数据库系统将自己管理的内存区按单元加锁,以防止一个任务在使用时被另一个任务修改。用完这个内存单元后,内存锁被立即释放。不过这篇文章只会论及sybase数据库的对象锁lock。 1锁类型:在sybase中的lock总共有10个类型:1-     排他表锁2-     共享表锁3-     排他意图锁4-     共享意图锁5-     排他页锁6-     共享页锁7- 

2、    更新页锁8-     排它行锁9-     共享行锁10-  更新行锁 这十类锁,从作用上来说,其实就是排他、共享和更新。其他的限定词无非说明锁的作用范围和作用时机。后面会详细说明,这里先说一下排他、共享和更新之间的兼容性问题。如下表所示:       共享锁更新锁排他锁共享锁兼容兼容不兼容更新锁兼容不兼容不兼容排他锁不兼容不兼容不兼容 简单说明一下这张表:比如共享锁和更新锁兼容,就是说加了共享锁,还可以加更新锁;排他锁和更新锁不兼容,就是说加了排他锁,就不可以再加更新锁。这里可以看到,加了排他锁后,就不能再加任何锁了。2锁方案:

3、锁方案有三类:Allpages、Datapages、Datarows。      Allpages:全页锁,这里全页的意思是包括索引页和数据页。      Datapages:数据页锁,设置这种锁方案后,只会对数据页加锁。      Datarows:数据行锁,设置这种锁方案后,只会对数据行加锁。      这里可以看到,Datapages和Datarows只会对数据加锁,不会对数据相对应的索引加锁。    有了锁方案的概念,就好理解排他表锁、排他页锁、排他行锁的含义了。比如:锁方案为Datarows,则会对表加XX行锁(XX可以是排他、

4、共享或者更新);锁方案为Allpages或Datapages,则会对表加XX页锁(XX可以是排他、共享或者更新)。 3意图锁和更新锁:这里将意图锁和更新锁单独列出来,原因是这两种锁只在某一个时机下才有,过了那个时机就没有了。意图锁:它是一种表级锁,表示在一个数据页上获得一个共享锁或排他锁的意图。意图锁可以防止其他事务在该数据页的表上获得排它锁。它分为排他意图锁和共享意图锁。更新锁:它是一种页级锁,它在一个更新操作开始时获得,当要修改这些页时,更新锁会升级为排它锁。 4各种操作的加锁过程:其实上面说的那么多,主要就是为了说明最开始列举的10

5、个锁类型。下面就谈谈这10个种类型的锁在实际操作中是如何加锁的。4.1假定锁方案为Allpages:4.1.1insert操作:      当向表中执行Insert操作时,会先在表上加一个排他意图锁,然后加上排他页锁。可以用下面的示意图表示。排他意图锁->排他页锁4.1.2select操作:      Select操作时,会先在表上加一个共享意图锁,然后加上共享页锁。示意图如下:共享意图锁->共享页锁4.1.3update操作:      Update操作时,加锁过程稍微复杂一点,首先会在表上加一个共享意图锁,然后加上共享页锁,接着会加更

6、新页锁,最后将更新页锁升级为排他页锁。      之所以有这么锁,实际上和update的机制有关。因为update操作在数据库中分两步执行:先select,然后update。示意图如下:共享意图锁->共享页锁->更新页锁->排他页锁4.1.4delete操作:      Delete操作时,首先会在表上加一个共享意图锁,然后加上共享页锁,最后加上排他页锁。      和update操作相比,少了一个更新页锁,这个锁只在update过程中存在。示意图如下:共享意图锁->共享页锁->排他页锁4.2假定锁方案为Datapages:加锁方式和al

7、lpages类似,只是allpages会对需要的索引页加锁,而datapages则不会对索引页加锁,所以叫“数据页锁”。4.3假定锁方案为Datarows:4.3.1insert操作:      当向表中执行Insert操作时,会先在表上加一个排他意图锁,然后加上排他行锁。可以用下面的示意图表示。排他意图锁->排他行锁4.3.2select操作:      Select操作时,会先在表上加一个共享意图锁,然后加上共享行锁。示意图如下:共享意图锁->共享行锁4.3.3update操作:      Update操作时,加锁过程稍微复杂一点,首

8、先会在表上加一个共享意图锁,然后加上共享行锁,接着会加更新行锁,最后将更新行锁升级为排他行锁。示意图如下:共享意图锁->共享行锁->更新行锁->排他行锁4.3.4delete操作:      

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。