page contents

C#通过哈希表hashtable批量上传数据

本文讲述了C#通过哈希表hashtable批量上传数据!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

attachments-2022-09-3lOhyNuQ6323d7123b05d.png本文讲述了C#通过哈希表hashtable批量上传数据!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

DAL层方法

  /// <summary> 
        ///为执行命令做参数准备     
        ///</summary>       
        ///<param >SqlCommand object</param>   
        ///<param >SqlConnection object</param>       
        ///<param >SqlTransaction object</param>       
        ///<param >一个存储过程,或者sql语句类型</param>     
        ///<param >一个命令sql语句</param>        
        ///<param >参数集合</param>       
        public static void PrepareCommand(SQLiteCommand cmd, SQLiteConnection conn, SQLiteTransaction trans, CommandType cmdType, string cmdText, SQLiteParameter[] cmdParms)
        {
            try
            {
                //判断连接的状态。如果是关闭状态,则打开                
                if (conn.State != ConnectionState.Open)
                    conn.Open();
                //cmd属性赋值                
                cmd.Connection = conn;
                cmd.CommandText = cmdText;                //是否需要用到事务处理      
                if (trans != null)
                    cmd.Transaction = trans;
                cmd.CommandType = cmdType;                //添加cmd需要的存储过程参数   
                if (cmdParms != null)
                {
                    foreach (SQLiteParameter parm in cmdParms)
                        cmd.Parameters.Add(parm);
                }
            }
            catch (Exception e)
            {
                throw new Exception(e.Message);
            }
        }

BLL层方法

        /// <summary>        
        /// 执行多条SQL语句,实现数据库事务。        
        /// </summary>        
        /// <param name="SQLStringList">SQL语句的哈希表(key为sql语句,value是该语句的SQLiteParameter[])</param>        
        public static void ExecuteSqlTran(Hashtable SQLStringList, ConnectionType type)
        {
            SQLiteConnection conn = GetConnection(type);
            if (conn.State == ConnectionState.Closed)
                conn.Open();
            using (SQLiteWriteLock sqliteLock = new SQLiteWriteLock(connString))
            {
                using (SQLiteTransaction trans = conn.BeginTransaction())
                {
                    SQLiteCommand cmd = new SQLiteCommand();
                    try
                    {
                        bool hadExce = false;
                        //循环                    
                        foreach (DictionaryEntry myDE in SQLStringList)
                        {
                            string cmdText = myDE.Key.ToString();
                            SQLiteParameter[] cmdParms = (SQLiteParameter[])myDE.Value;
                            PrepareCommand(cmd, conn, trans, CommandType.Text, cmdText, cmdParms);
                            int val = cmd.ExecuteNonQuery();
                            cmd.Parameters.Clear();
                            hadExce = true;
                        }
                        if (hadExce)
                        {
                            trans.Commit();
                        }

                    }
                    catch (System.Data.SQLite.SQLiteException e)
                    {
                        trans.Rollback();
                        conn.Close();
                        throw new Exception(e.Message);
                    }
                }
            }
        }

UI层

 Hashtable hashtb = new Hashtable();
                    for (int i = 0; i < dtOrderDetail.Rows.Count; i++)
                    {
                        string prodcode = dtOrderDetail.Rows[i]["?"].ToString();
                        string colorcode = dtOrderDetail.Rows[i]["?"].ToString();
                        string pattern = dtOrderDetail.Rows[i]["?"].ToString();
                        DateTime WNo = (DateTime)dtOrderDetail.Rows[i]["?"];
                        SQLiteParameter[] parameters = {
                            new SQLiteParameter("@?", DbType.String),
                            new SQLiteParameter("@?", DbType.String),
                            new SQLiteParameter("@?", DbType.String),
                            new SQLiteParameter("@?", DbType.DateTime)};
                        parameters[0].Value = ?;
                        parameters[1].Value = ?;
                        parameters[2].Value = ?;
                        parameters[3].Value = ?;
                        hashtb.Add("update OrderDetail set ? where ? and ? and ?and ? and ?and " + i + "=" + i, parameters);
                    }
SqliteClass.ExecuteSqlTran(hashtb, SqliteClass.ConnectionType.Biz);

更多相关技术内容咨询欢迎前往并持续关注六星社区了解详情。

想高效系统的学习Python编程语言,推荐大家关注一个微信公众号:Python编程学习圈。每天分享行业资讯、技术干货供大家阅读,关注即可免费领取整套Python入门到进阶的学习资料以及教程,感兴趣的小伙伴赶紧行动起来吧。

attachments-2022-05-rLS4AIF8628ee5f3b7e12.jpg

  • 发表于 2022-09-16 09:53
  • 阅读 ( 349 )
  • 分类:C/C++开发

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
轩辕小不懂
轩辕小不懂

2403 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. 小柒 1474 文章
  3. Pack 1135 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章