DbHelperSQL 增加事务处理方法(2种)

Posted ——君——

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DbHelperSQL 增加事务处理方法(2种)相关的知识,希望对你有一定的参考价值。

方法一: 
1
public static bool ExecuteSqlByTrans(List<SqlAndPrams> list) 2 { 3 bool success = true; 4 Open(); 5 SqlCommand cmd = new SqlCommand(); 6 SqlTransaction trans = Connection.BeginTransaction(); 7 cmd.Connection = Connection; 8 cmd.Transaction = trans; 9 try 10 { 11 foreach (SqlAndPrams item in list) 12 { 13 if (item.cmdParms == null) 14 { 15 cmd.CommandText = item.sql; 16 cmd.ExecuteNonQuery(); 17 } 18 else 19 { 20 cmd.CommandText = item.sql; 21 cmd.CommandType = CommandType.Text;//cmdType; 22 cmd.Parameters.Clear(); 23 foreach (SqlParameter parameter in item.cmdParms) 24 { 25 if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) && (parameter.Value == null)) 26 { 27 parameter.Value = DBNull.Value; 28 } 29 cmd.Parameters.Add(parameter); 30 } 31 cmd.ExecuteNonQuery(); 32 } 33 34 } 35 trans.Commit(); 36 } 37 catch (Exception e) 38 { 39 success = false; 40 trans.Rollback(); 41 } 42 finally 43 { 44 Close(); 45 } 46 return success; 47 }

方法一对应的实体类:
1 public class SqlAndPrams
2     {
3         public string sql { get; set; }
4 
5         public SqlParameter[] cmdParms { get; set; }
6     }

DAL层代码:

 1 /// <summary>
 2         /// 增加一条数据
 3         /// </summary>
 4         public SqlAndPrams AddAccount(Entity.Account_T model)
 5         {
 6             SqlAndPrams result = new SqlAndPrams();
 7             StringBuilder strSql = new StringBuilder();
 8             strSql.Append("insert into Account_T(");
 9             strSql.Append("AccountNo,Type,Count,LoginName,Remark,CreateTime)");
10             strSql.Append(" values (");
11             strSql.Append("@AccountNo,@Type,@Count,@LoginName,@Remark,@CreateTime)");
12             strSql.Append(";select @@IDENTITY");
13             SqlParameter[] parameters = {
14                     new SqlParameter("@AccountNo", SqlDbType.NVarChar,20),
15                     new SqlParameter("@Type", SqlDbType.NVarChar,10),
16                     new SqlParameter("@Count", SqlDbType.Int,4),
17                     new SqlParameter("@LoginName", SqlDbType.NVarChar,30),
18                     new SqlParameter("@Remark", SqlDbType.NVarChar,50),
19                     new SqlParameter("@CreateTime", SqlDbType.DateTime)};
20             parameters[0].Value = model.AccountNo;
21             parameters[1].Value = model.Type;
22             parameters[2].Value = model.Count;
23             parameters[3].Value = model.LoginName;
24             parameters[4].Value = model.Remark;
25             parameters[5].Value = model.CreateTime;
26 
27             result.sql = strSql.ToString();
28             result.cmdParms = parameters;
29             return result;
30         }

调用层:

1 List<SqlAndPrams> updateList = new List<SqlAndPrams>();
2 Entity.Account_T model_account = new Entity.Account_T();
3 model_account.CreateTime = DateTime.Now;
4 model_account.LoginName = userName;
5 model_account.Type = "消费";
6 model_account.Count = -num;                        updateList.Add(dal_tran.AddAccount(model_account)); //添加进事务
7 DbHelperSQL.ExecuteSqlByTrans(updateList)   //调用执行

 



方法二:暂时没有用,没有调用例子
 1 public static bool ExecuteSQL2(string[] SqlStrings)
 2         {
 3             bool success = true;
 4             Open();
 5             SqlCommand cmd = new SqlCommand();
 6             SqlTransaction trans = Connection.BeginTransaction();
 7             cmd.Connection = Connection;
 8             cmd.Transaction = trans;
 9             try
10             {
11                 foreach (string str in SqlStrings)
12                 {
13                     cmd.CommandText = str;
14                     cmd.ExecuteNonQuery();
15                 }
16                 trans.Commit();
17             }
18             catch
19             {
20                 success = false;
21                 trans.Rollback();
22             }
23             finally
24             {
25                 Close();
26             }
27             return success;
28         }

 

 






以上是关于DbHelperSQL 增加事务处理方法(2种)的主要内容,如果未能解决你的问题,请参考以下文章

MYSQL 事务处理常见有两种方法

微服务异常的三种场景和处理方法

关于DataSet事务处理以及SqlDataAdapter四种用法

DbHelperSQL.cs(20190119)

ⓂMySQLMySQL三种并发问题以及四种隔离级别

MySQL 事务详解