- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Sybase中的锁及死锁问题一般来说,数据库都会有两种锁:内存锁和对象锁。Oracle中有latch和lock,sybase中有spinlock和lock。内存锁实际上就是数据库系统将自己管理的内存区按单元加锁,以防止一个任务在使用时被另一个任务修改。用完这个内存单元后,内存锁被立即释放。不过这篇文章只会论及sybase数据库的对象锁lock。
?
1锁类型:
在sybase中的lock总共有10个类型:
1-????? 排他表锁
2-????? 共享表锁
3-????? 排他意图锁
4-????? 共享意图锁
5-????? 排他页锁
6-????? 共享页锁
7-????? 更新页锁
8-????? 排它行锁
9-????? 共享行锁
10-?? 更新行锁
?
这十类锁,从作用上来说,其实就是排他、共享和更新。其他的限定词无非说明锁的作用范围和作用时机。后面会详细说明,这里先说一下排他、共享和更新之间的兼容性问题。如下表所示:
??????
? 共享锁 更新锁 排他锁 共享锁 兼容 兼容 不兼容 更新锁 兼容 不兼容 不兼容 排他锁 不兼容 不兼容 不兼容 ?
简单说明一下这张表:
比如共享锁和更新锁兼容,就是说加了共享锁,还可以加更新锁;
排他锁和更新锁不兼容,就是说加了排他锁,就不可以再加更新锁。
这里可以看到,加了排他锁后,就不能再加任何锁了。
2锁方案:
锁方案有三类:Allpages、Datapages、Datarows。
?????? Allpages:全页锁,这里全页的意思是包括索引页和数据页。
?????? Datapages:数据页锁,设置这种锁方案后,只会对数据页加锁。
?????? Datarows:数据行锁,设置这种锁方案后,只会对数据行加锁。
?????? 这里可以看到,Datapages和Datarows只会对数据加锁,不会对数据相对应的索引加锁。????
有了锁方案的概念,就好理解排他表锁、排他页锁、排他行锁的含义了。
比如:锁方案为Datarows,则会对表加XX行锁(XX可以是排他、共享或者更新);
锁方案为Allpages或Datapages,则会对表加XX页锁(XX可以是排他、共享或者更新)。
?
3意图锁和更新锁:
这里将意图锁和更新锁单独列出来,原因是这两种锁只在某一个时机下才有,过了那个时机就没有了。
意图锁:它是一种表级锁,表示在一个数据页上获得一个共享锁或排他锁的意图。意图锁可以防止其他事务在该数据页的表上获得排它锁。它分为排他意图锁和共享意图锁。
更新锁:它是一种页级锁,它在一个更新操作开始时获得,当要修改这些页时,更新锁会升级为排它锁。
?
4各种操作的加锁过程:
其实上面说的那么多,主要就是为了说明最开始列举的10个锁类型。下面就谈谈这10个种类型的锁在实际操作中是如何加锁的。
4.1 假定锁方案为Allpages:
4.1.1 insert操作:
?????? 当向表中执行Insert操作时,会先在表上加一个排他意图锁,然后加上排他页锁。可以用下面的示意图表示。
排他意图锁-排他页锁
4.1.2 select操作:
?????? Select操作时,会先在表上加一个共享意图锁,然后加上共享页锁。示意图如下:
共享意图锁-共享页锁
4.1.3 update操作:
?????? Update操作时,加锁过程稍微复杂一点,首先会在表上加一个共享意图锁,然后加上共享页锁,接着会加更新页锁,最后将更新页锁升级为排他页锁。
?????? 之所以有这么锁,实际上和update的机制有关。因为update操作在数据库中分两步执行:先select,然后update。示意图如下:
共享意图锁-共享页锁-更新页锁-排他页锁
4.1.4 delete操作:
?????? Delete操作时,首先会在表上加一个共享意图锁,然后加上共享页锁,最后加上排他页锁。
?????? 和update操作相比,少了一个更新页锁,这个锁只在update过程中存在。示意图如下:
共享意图锁-共享页锁-排他页锁
4.2 假定锁方案为Datapages:
加锁方式和allpages类似,只是allpages会对需要的索引页加锁,
而datapages则不会对索引页加锁,所以叫“数据页锁”。
4.3 假定锁方案为Datarows:
4.3.1 insert操作:
?????? 当向表中执行Insert操作时,会先在表上加一个排他意图锁,然后加上排他行锁。可以用下面的示意图表示。
排他意图锁-排他行锁
4.3.2 select操作:
?????? Select操作时,会先在表上加一个共享意图锁,然后加上共享行锁。示意图如下:
共享意图锁-共享行锁
4.3.3 update操作:
?????? Update操作时
您可能关注的文档
- 【pascal教程】【免费】第1节 初识pascal语言.ppt
- 【RTX操作系统教程】第21篇 RTX低功耗之睡眠模式.pdf
- 【VBA教材】数据类型及变量、常量的概念.doc
- 【宝贝瞬间换装】批量安装及更换宝贝描述模板的诀窍.doc
- 【技术资料】游标卡尺与千分尺的读数方法及使用注意事项.doc
- 【讲解】自助借还书机操作流程和注意事项.ppt
- 【精】高考语文 考纲要求掌握二十个虚词.doc
- 【数据库系统原理及应用】目录.ppt
- 【图文教程】用护卫神·主机管理系统在WindowsServer2012下开设网站与数据库.doc
- 【项目一 零件尺寸测量】任务一 用游标卡尺测量零件尺寸.ppt
- 实验室危废随意倾倒查处规范.ppt
- 实验室危废废液处理设施规范.ppt
- 实验室危废处置应急管理规范.ppt
- 初中地理中考总复习精品教学课件课堂讲本 基础梳理篇 主题10 中国的地理差异 第20课时 中国的地理差异.ppt
- 初中地理中考总复习精品教学课件课堂讲本 基础梳理篇 主题10 中国的地理差异 第21课时 北方地区.ppt
- 危险废物处置人员防护培训办法.ppt
- 危险废物处置隐患排查技术指南.ppt
- 2026部编版小学数学二年级下册期末综合学业能力测试试卷(3套含答案解析).docx
- 危险废物处置违法案例分析汇编.ppt
- 2026部编版小学数学一年级下册期末综合学业能力测试试卷3套精选(含答案解析).docx
最近下载
- 2023年秋国开《管理思想史》形考作业1-4答案.pdf
- 小学一年级数学上册期末试卷(A4打印版).pdf VIP
- 旅游学概论期末考试试题及解析.docx VIP
- 自贡市餐厨垃圾处理配套设施改建项目环评报告书.pdf VIP
- 《音乐之父巴赫》课件.ppt VIP
- 【中考短语】初中英语动词固定搭配全汇总.pdf VIP
- 射频设计软件:Keysight ADS二次开发_(7).Python脚本在KeysightADS中的应用.docx VIP
- 2025年民主生活会100条核心素材.pdf VIP
- (直接打印版)苏教版小学数学一年级上册期末试卷.pdf VIP
- 酒店拆除改造工程专项拆除施工方案.docx VIP
原创力文档


文档评论(0)