不用SqlTransaction执行数据库事务处理

Admin | 2008-2-11 20:09:07 | TrackRecord: 1591 Times | Tag标签:数据库Sql,VFP,Access 打印本页

您当前所处的位置是:〖首页〗→【文章页】 本站共有16个图文教程栏目,请用心拜读!

本站提供经典的Excel公式函数实例,Word排版技巧,PPT教程;同时更兼有Flash,PowerPoint,数据库等技术文章。

        在实际工作的中,很多人经常需要实现数据库的事务,如果每次都用SqlTransaction 写代码,是一件特别麻烦的事,下面我们来介绍一个通用的方法放在数据层,以此来达到复用的目的并能满足一般情况下的需求。

        可以同时执行两条SQL语句的方法:

public static void ExecuteSqlTran(string SQLString1,string SQLString2)
  {
   using (SqlConnection conn = new SqlConnection(strDBConnectionString))
   {
    conn.Open();
    SqlCommand cmd = new SqlCommand();
    cmd.Connection=conn;   
    SqlTransaction tx=conn.BeginTransaction();  
    cmd.Transaction=tx;   
    try
    {    
     cmd.CommandText=SQLString1;
     cmd.ExecuteNonQuery();
     cmd.CommandText=SQLString2;
     cmd.ExecuteNonQuery();    
     tx.Commit();    
    }
    catch(System.Data.SqlClient.SqlException E)
    { 
     tx.Rollback();
     throw new Exception(E.Message);
    }
   }
  }
假如有多条SQL语句需要放在一个事务里实现执行,大家就可以用下面这个方法:
/// <summary>
  /// 执行多条SQL语句,实现数据库事务。
  /// </summary>
  /// <param name="SQLStringList">多条SQL语句</param> 
  public static void ExecuteSqlTran(ArrayList SQLStringList)
  {
   using (SqlConnection conn = new SqlConnection(connectionString))
   {
    conn.Open();
    SqlCommand cmd = new SqlCommand();
    cmd.Connection=conn;   
    SqlTransaction tx=conn.BeginTransaction();  
    cmd.Transaction=tx;   
    try
    {    
     for(int n=0;n<SQLStringList.Count;n++)
     {
      string strsql=SQLStringList[n].ToString();
      if (strsql.Trim().Length>1)
      {
       cmd.CommandText=strsql;
       cmd.ExecuteNonQuery();
      }
     }         
     tx.Commit();    
    }
    catch(System.Data.SqlClient.SqlException E)
    { 
     tx.Rollback();
     throw new Exception(E.Message);
    }
   }
  }



上一篇:SQL各种常用数值(数据)运算函数详解    下一篇:数据库备份之九种常见情况

会员评论列表:
针对本篇文章或本站,请您发表个人的建议或批评!
FreeBoxPc

谷歌搜索 百度搜索 本站仅与内容具备一定的实用价值的原创网站交换友情链接,力争为大众做出更优质的服务!
All Rights Reserved版权所有 本站备案信息:滇ICP备11001339号-2 站长联系方式 Email:dzwebs@126.com