C# 启用事务提交多条带参数的SQL语句实例代码

 更新时间:2018年02月28日 10:48:13   作者:liyanzhao  
这篇文章主要介绍了C# 启用事务提交多条带参数的SQL语句实例代码,需要的朋友可以参考下

具体代码如下所示:

/// <summary>
 /// 启用事务提交多条带参数的SQL语句
 /// </summary>
 /// <param name="mainSql">主表SQL</param>
 /// <param name="mainParam">主表对应的参数</param>
 /// <param name="detailSql">明细表SQL语句</param>
 /// <param name="detailParam">明细表对应的参数</param>
 /// <returns>返回事务是否成功</returns>
 public static bool UpdateByTran(string mainSql, SqlParameter[] mainParam, string detailSql, List<SqlParameter[]> detailParam)
 {
  SqlConnection conn = new SqlConnection(connString);
  SqlCommand cmd = new SqlCommand();
  cmd.Connection = conn;
  try
  {
   conn.Open();
   cmd.Transaction = conn.BeginTransaction();//开启事务
   if (mainSql != null && mainSql.Length != 0)
   {
    cmd.CommandText = mainSql;
    cmd.Parameters.AddRange(mainParam);
    cmd.ExecuteNonQuery();
   }
   foreach (SqlParameter[] param in detailParam)
   {
    cmd.CommandText = detailSql;
    cmd.Parameters.Clear();
    cmd.Parameters.AddRange(param);
    cmd.ExecuteNonQuery();
   }
   cmd.Transaction.Commit();//提交事务
   return true;
  }
  catch (Exception ex)
  {
   if (cmd.Transaction != null)
   {
    cmd.Transaction.Rollback();//回滚事务
   }
   //将异常信息写入日志
   string errorInfo = "调用UpdateByTran(string mainSql, SqlParameter[] mainParam,string detailSql ,List <SqlParameter []>detailParam)方法时<br data-filtered="filtered">发生错误,具体信息:" + ex.Message;
   WriteLog(errorInfo);
   throw ex;
  }
  finally
  {
   if (cmd.Transaction != null)
   {
    cmd.Transaction = null;//清空事务
   }
   conn.Close();
  }
 }

总结

以上所述是小编给大家介绍的C# 启用事务提交多条带参数的SQL语句,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • C#读取二进制文件方法分析

    C#读取二进制文件方法分析

    这篇文章主要介绍了C#读取二进制文件方法,较为详细的分析了C#读取二进制文件的原理与注意事项,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-01-01
  • 详解C#数据类型及其转换

    详解C#数据类型及其转换

    这篇文章主要介绍了C#数据类型及其转换详解,在C#中,数据类型可以分为几种类型,今天小编通过本文给大家详细介绍,需要的朋友可以参考下
    2020-07-07
  • C#运行程序时阻止关闭显示器和系统待机

    C#运行程序时阻止关闭显示器和系统待机

    这篇文章介绍了C#运行程序时阻止关闭显示器和系统待机的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • C#实现listview Group收缩扩展的方法

    C#实现listview Group收缩扩展的方法

    这篇文章主要介绍了C#实现listview Group收缩扩展的方法,结合实例形式分析了listview控件的相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-03-03
  • C#实现插入排序算法实例

    C#实现插入排序算法实例

    这篇文章主要介绍了C#实现插入排序算法,实例分析了插入排序算法的原理与实现技巧,需要的朋友可以参考下
    2015-05-05
  • C#  ADO.NET 离线查询的实现示例

    C# ADO.NET 离线查询的实现示例

    这篇文章主要介绍了C# ADO.NET 离线查询的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-05-05
  • C# 字符串处理小工具

    C# 字符串处理小工具

    本文主要介绍C#字符串处理小工具,实现功能包括:转换为大写;转换为小写;反转字符串;匹配某字符串出现次数;正则匹配;base64加密;base64解密;ROT13加密解密;MD5 32位加密。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • C#简单获取时间差的小例子

    C#简单获取时间差的小例子

    C#简单获取时间差的小例子,需要的朋友可以参考一下
    2013-04-04
  • C# GetField方法的应用实例讲解

    C# GetField方法的应用实例讲解

    C#中的GetField是一个反射方法,用于获取指定类型的字段信息,它可以通过字段名称来获取字段对象,并且可以在运行时动态地访问和操作这些字段,本文给大家介绍了C# GetField方法的应用,需要的朋友可以参考下
    2024-04-04
  • WPF使用触发器需要注意优先级问题解决

    WPF使用触发器需要注意优先级问题解决

    本文主要介绍了WPF使用触发器需要注意优先级问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01

最新评论