asp.net 数据库连接 使用事务处理(一)

     在.net中,事务处理机制共有四种:数据库事务;ADO.NET事务;ASP.NET事务;企业服务及事务。

     ASP.NET事务是在Web应用程序的页面层工作,只需简单的在页面属性中加一个"Transaction="Required"",这样页面中的时间处理都作为页面整个事务的 一部分,该页面的任何处理出现问题,所以的处理都会回滚。

  为了执行一个ADO.NET事务,首先需要创建一个SqlTransaction对象,可以调用SqlConnection对象的BeginTransaction()方法来创建SqlTransaction对象。然后把它赋给SqlCommand对象的事务属性。当事务开始后,就可以执行任意次数的SqlCommand动作,但要保证SqlCommand对象属于同一个事务和连接。执行成功后,使用SqlTransaction的Commit()方法提交事务,否则使用SqlTransaction的Rollback()方法回滚事务。

  实例代码如下:

  SqlTransaction tran=null;

  using(SqlConnection cnn=new SqlConnection(连接路径))

  {

    

    try
    {
      cnn.open();
      //调用SqlConnection的BeginTransaction方法开启一个事务
      //并返回已经开启的事务
      tran=cnn.BeginTransaction();
      SqlCommand cmd=new SqlCommand();
      cmd.Transaction=tran;
      //...数据库访问代码
      tran.Commit();
    }
    catch(Exception ex)
    {
      tran.RollBack();
    }
    finally{cnn.close();}

  }

也可以使用TransactionOptions配置事务设置

在使用TransactionOptions时要先引用System.Transactions。

实例代码:

  TransactionOptions opt = new TransactionOptions();
  opt.IsolationLevel = System.Transactions.IsolationLevel.Serializable;
  using (CommittableTransaction tran = new CommittableTransaction(opt))

  {

    try

    {

      //几个要绑定成同一个事务处理方法

      tran.Commit();

    }

    catch(Exception ex)
    {
      tran.RollBack();
    }

  }

 

 

 

转载于:https://www.cnblogs.com/itmangelihai/archive/2012/05/21/2512082.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值