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();
    }

  }

 

 

 

posted on 2012-05-21 19:13  小海少  阅读(328)  评论(0编辑  收藏  举报