c语言程序设计课件ch14简述事务_第1页
c语言程序设计课件ch14简述事务_第2页
c语言程序设计课件ch14简述事务_第3页
c语言程序设计课件ch14简述事务_第4页
c语言程序设计课件ch14简述事务_第5页
免费预览已结束,剩余10页可下载查看

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 事务2011.11周舟本章目标什么是事务 如何提供事务支持如何利用 事务写入数据事务的基本隔离级别1.1 什么是事务示例假设要把¥1000 从账户A转到账户B - ¥1000 + ¥1000AB 假设成功的完成了步骤1,但是由于一些错误,步骤2失败。 如果不取消步骤1,那么整个操作将出错。 使用事务后,只有所有的步骤都成功后,操作才会改变数据库 1.1 什么是事务事务是一组要么全部成功,要么全部失败的操作案例演示1.1 什么是事务 SqlConnection conn = new SqlConnection(connectionString); conn.Open(); SqlTransac

2、tion trans = conn.BeginTransaction(); mand cmd = new mand(str, conn, trans); try cmd.ExecuteNonQuery(); mit(); return true; catch trans.Rollback(); return false; finally conn.Close(); 1.2 事务的特点 ACIDAtomic(原子性)Consistent(一致性)Isolated(隔离性) Durable(持久性)所有步骤要么成功执行要么都不执行保证数据库的稳定状态每个事务都是独立的不会影响其他的事务事务在执行成

3、功前,任何改变将永久存储在硬盘上1.3 事务类数据提供者类命名空间OleDBOleDbTransactionSystem.Data.OleDbSqlClientSqlTransactionSystem.Data.SqlClinetODBCODBCTransactionSystem.Data.ODBC1.4 事务类的方法方法说明BeginTransactioin 此方法启动一个事务。这个方法为我们提供一个事务对象。这个事务对象将被用于提交或回滚事务Commit 此方法把一个事务标记为成功。一旦调用此方法,所有未决的改变将永久地写入数据库Rollback 此方法把一个事务标记为失败。悬而未决的改变

4、将被丢弃。数据库状态保持不变。2.1 的事务支持 提供了数据的连接和断开访问,并且在这两种模式下都提供了对事务的支持连接模式下事务的操作步骤打开一个数据库连接启动一个事务通过命令对象激活对连接的直接操作提交或回滚事务断开连接案例演示2.1 的事务支持在断开模式下,通常把数据存放到一个DATASET对象中,并按要求进行操作,然后更新数据库中的数据。断开模式下事务的操作步骤打开一个数据库连接为一个DataSet对象取得必要的数据断开数据库连接操作DataSet里的数据重新打开一个数据库连接启动一个事务用DataSet里的改变更新数据库断开这个连接案例演示3.1 设置隔离级别什么是隔离级别 隔离级别通常用于衡量一个事务外面的改变对此事务内部的可见程度。 如果两个事务各自对立运行,由一个事务插入的记录,在另一个事务里是不可见的,除非第一个事务已经提交。 我们可能想改变事务的这种行为,是第二个事务可以见到第一个事务插入的记录。通过相应的设置隔离界别的属性可以达到这种目的。3.1 设置隔离级别枚举类型说明 mitted 比如我们要处理某一特定的数据,而不管它有没有被提交时,使用这一隔离级别设置 mitted 如果我们要处理某一特定的并且已提交的数据时,使用这个隔离级别设置通过访问事务对象的IsoIationLevel属性,可以读取隔离级别的当前值案例演示3.2 什么时候使用事务

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论