从零开始学SQLServer——第9章事务和锁.pptVIP

从零开始学SQLServer——第9章事务和锁.ppt

  1. 1、本文档共20页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第9章 事务和锁 SQL Server数据库有四个显著特征,即安全性、完整性、并发性和监测性。数据的完整性是通过一系列逻辑来保障的,这些逻辑分为三个方面,即实体完整性、域完整性和参考完整性。为了保证数据库数据的完整性,SQL Server提供了多种保证机制,如约束、触发器、事务和锁管理等。事务管理主要是为了保证一批相关数据库数据的操作能全部被完成,从而保证数据的完整性。锁机制主要是处理多个活动事务的并发。锁是一个非常重要的概念,它是用来控制多个用户对同一数据进行的操作,通过使用锁机制,解决了数据库的并发性问题。本章内容主要包括: 事务管理的常用语句 事物管理的类型 锁的类型 9.1 事务管理 事务是SQL Server的基本工作单元,事务内的语句被作为一个整体执行,从而保证数据的可恢复性和一致性。SQL Server的事务由两种类型,分别是隐式事务和显式事务。隐式事务是根据T-SQL语句自身的特点形成的事务,比如插入(INSERT)、删除(DELETE)和更新(UPDATE)等,这些语句的执行默认为一个完整的事务,显式事务是用户使用语句定义的。 9.1.1 事务的原理 使用UPDATE来对数据库进行更新时,一次只能操作一个表。但事实当应用要求对多个表的数据进行更新操作时,就又可能带来数据库操作的不一致问题。为此要将整个过程设置为要么完成操作,要么一步也不完成,这就是数据库中的事物。 1.事务的内涵 2.事务的属性 3.事务日志 4.建立事务应遵循的原则 9.1.2 事务管理的常用语句 SQL Server事务管理的语句包括如下几条: BEGIN TRANSACTION COMMIT TRANSACTION ROLLBACK TRANSACTION SAVE TRANSACTION BEGIN TRANCATION用来建立一个事务,COMMIT TRANSACTION表示提交事务,ROLLBACK TRANSACTION用来执行事务失败时的回滚操作,SAVE TRANSACTION表示保存事务。其中,BEGIN TRANSACTION和COMMIT TRANSACTION应该同时用用,用来标识事务的开始和结束。 9.1.3 事务恢复和检查点机制 虽然现在计算机的软硬件系统和网络环境的可靠性已经有了很大的提高,当仍然做不到万无一失,各种人为的操作失误、病毒的破坏等都对数据库系统造成了很大的威胁。SQL Server实例在事务日志总存储足够的信息来恢复和撤销构成事务的数据修改。 为了减少频繁对磁盘读写操作,提高系统运行的速度,SQL Server在内存中建立了一个缓冲区,来存放被操作的数据,等出现检查点的时候才将缓冲区中的数据写回磁盘。在检索数据时,先将数据读到缓冲区;修改数据时也是先将数据读到缓冲区,再对缓冲区内的数据进行修改。缓冲区中未写回磁盘的数据页面,叫做脏页。 9.1.4 事务的类型 SQL Server事务的类型包括以下几种: 自动处理事务: 隐式事务: 用户定义事务: 分布式事务: 1.显式事务 2.隐式事务 3.自动事务 9.1.4 事务的类型 9.1.4 事务的类型 9.1.5 事务的应用案例 事物和后面要提到的锁在数据更新时要保证数据的一致性,在SQL Server2005中是一个难点,为了使读者更加清楚的认识事物的应用,本小节中,将使用一个综合性的实例来展示事务的强大处理功能,使读者在具体应用中对内容得以掌握。 1.选择4门课程(最高限选5门) 2.验证所选课程 3.选择6门课程(最高限选5门) 4.验证所选课程 9.1.5 事务的应用案例 9.1.5 事务的应用案例 9.2 锁 事务是SQL Server的基本工作单元,事务内的语句被作为一个整体执行,从而保证数据的可恢复性和一致性。SQL Server的事务由两种类型,分别是隐式事务和显式事务。隐式事务是根据T-SQL语句自身的特点形成的事务,比如插入(INSERT)、删除(DELETE)和更新(UPDATE)等,这些语句的执行默认为一个完整的事务,显式事务是用户使用语句定义的。 9.2.1 锁的内涵与作用 数据库开发过程中,对数据的并发操作是经常发生的,而对数据的并发操作会带来如下数据不一致的问题: 1.丢失更新 2.脏读 3.不可重复读 4.幻读 9.2.2 可锁定资源与锁的类型 SQL Server 2005具有多粒度锁定,允许一个事务锁定不同类型的资源。为了使锁定的成本减至最少,SQL Server自动将资源锁定在适合任务的级别。锁定在较小的粒度(例如行)可以增加并发但需要较大的开销,因为如果锁定了许多行,则需要控制更多的锁。锁定在较大的粒度(例如表)就并发而言是相当昂贵的,因为锁定整个表限制了其他事务对表中任意部分进

文档评论(0)

天马行空 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档