.Net中使用事务x_第1页
.Net中使用事务x_第2页
.Net中使用事务x_第3页
.Net中使用事务x_第4页
免费预览已结束,剩余1页可下载查看

下载本文档

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

文档简介

:在ADO.NET中使用事务:在ADO.net中主要通过Transaction对象来实现事务的基本处理。SqlConnection和OledbConnection对象有一个BeginTransaction方法,该方法返回一个SqlTransaction或者OleDBTransaction对象,而这两个对象中Commit和RollBack方法来管理事务处理。很简便明了其中在ADO.net主要特点是:优点是:(A)操作简单(主要是对象几个方法)和数据库事务差不多(B)独立于数据库 不同数据库专有代码被隐藏了缺点是:(A)事务不能跨多个数据库连接(分布式事务可以跨多个数据库)(B)事务执行必须依靠一个存在的数据库连接,从Transaction对象生成就可以看出通过SqlConnection或OleDBConnection对象获得。(C)ADO.net中分布式事务可以跨多个数据库,如果其中一个是SQLServer数据库的话,通过SQLserver连接服务器连接别的数据库,但如果是DB2和Oracle之间就不行。如下实例代码:-在ADO.net中添加事务-连接字符串已知conStrusing(SqlConnenctiongetCon=newSqlConnection(conStr)/openConnectiongetCon.open();/声明一个SqlTransactionSqlTransactiongetTran=getCon.BeginTransaction();SqlCommandgetCmd=newSqlCommand();getCmd.Connection=getCon;/定义命令操作事务getCmd.Transaction=getTran;/通过一个Try-Catchtry/执行第一条SQL语句getCmd.CommandText=insertintoOrderList(德国柏林);getCmd.ExecuteNonQuery();/执行第二条SQL语句getCmd.CommandText=deletefromOrderListwhereid=1425;getCmd.ExecuteNonQuery();/若没有异常提交事务getTran.Commit();catch(Exceptionce)/出现异常事务回滚getTran.RollBack();finally/关闭数据库连接使用了Using快就不需要了/getCom.close();其中他的Save方法是在事务中创建保存点,可以回滚事务的一部分如果没有锁定且多个用户同时访问一个数据库,则当他们的事务同时使用相同的数据时可能会发生问题。并发问题包括: 丢失或覆盖更新,未确认的相关性(脏读),不一致的分析(非重复读),幻像读。而在.net框架中,同样支持事务的隔离级别。我们可以通过System.Data.IsolationLevel 来实现:public virtual IsolationLevel IsolationLevel get; 其成员及相应的含义如下:成员名称说明值Chaos 受 .NET Framework 精简版的支持。无法改写隔离级别更高的事务中的挂起的更改。ReadCommitted 在正在读取数据时保持共享锁,以避免脏读,但是在事务结束之前可以更改数据,从而导致不可重复的读取或幻像数据。ReadUncommitted 可以进行脏读,意思是说,不发布共享锁,也不接受独占锁。RepeatableRead 在查询中使用的所有数据上放置锁,以防止其他用户更新这些数据。防止不可重复的读取,但是仍可以有幻像行。Serializable 在 DataSet 上放置范围锁,以防止在事务完成之前由其他用户更新行或向数据集中插入行。问题简要描述解释脏读取当一个事务读取其它完成一半事务的记录时,就会发生脏读取 用户A和用户B看到的值都是5 用户B将值修改为2 用户A看到的值仍然是5,这时就发生了脏读取不可重复读取在每次读数据时,如果你获得的值都不一样,那表明你遇到了不可重复读取问题 用户A看到的值是5 用户B将值改为2 用户A刷新后看到的值仍然是5,这时就发生了不可重复读取虚幻行如果update和delete SQL语句未对数据造成影响,很可能遇到了虚幻行问题 用户A将所有值从5修改为2 用户B使用值2插入一个新记录 用户A查询所有值为2的记录,但却找不到,这时就发生了虚幻行更新丢失一个事务的更新覆盖了其它事务的更新结果,就是所谓的更新丢失 用户A将所有值从5更新为2 用户B将所有值从2更新到5 用户A丢失了他的更新COM+分布式事务 public string testTransaction()tryContextUtil.EnableCommit();InsertARecord1();InsertARecord2(); ContextUtil.SetComplete();return succeed!;catch(Exception ex)ContextUtil.SetAbort(); return failed!; public void InsertARecord1()string strconn=workstation id=WEIXIAOPING;packet size=4096;user id=sa;initial catalog=Northwind;persist security info=False;SqlConnection conn=new SqlConnection(strconn);conn.Open();SqlCommand command=new SqlCommand(insert into tbTree(Context,ParentID) values(北京,1),conn);command.ExecuteNonQuery();conn.Close(); public void InsertARecord2()string strconn=workstation id=WEIXIAOPING;packet size=4096;user id=sa;initial catalog=Northwind;persist security info=False;SqlConnection conn=new SqlConnection(strconn);c

温馨提示

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

评论

0/150

提交评论