亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#使用Datatable導入sqlserver數(shù)據(jù)庫的三種方法

 更新時間:2024年08月15日 10:30:24   作者:新時代丘鳴山  
本文主要介紹了C#使用Datatable導入sqlserver數(shù)據(jù)庫的三種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

第一種,最常見的Executenonquery(返回影響的行數(shù))sql是我的查詢插入語句,你可以換成你的!這種方式入庫,速度一般,大量數(shù)據(jù)時不提倡使用

/// <summary>
        /// 通過table一個一個的插入
        /// </summary>
        /// <param name="table"></param>
        public static void Executenonquery(DataTable table)
        {
            foreach (DataRow itemRow in table.Rows)
            {
                //if exists(select * from dbo.ID where ENG = '')
                //   begin
                //        return;
                //                end
                //else
                //   begin
                //        INSERT INTO ID([ENG],[GB],[B5],[FILE],[MSG]) values('', '', '', '', '')
                //   end
                string sql = "if exists(select * from " + table.TableName + " where ENG = '" + itemRow["ENG"].ToString() + "') "+
                             " begin return; end else begin INSERT INTO " + table.TableName + "([ENG],[GB],[B5],[FILE],[MSG])" +
                             "VALUES('" + itemRow["ENG"].ToString() + "'" +
                             ",'" + itemRow["GB"].ToString() + "'" +
                             ",'" + itemRow["B5"].ToString() + "'" +
                             ",'" + itemRow["FILE"].ToString() + "'" +
                             ",'" + itemRow["MSG"].ToString() + "') end";
                using (SqlConnection sqlconn = new SqlConnection(connectString))
                {
                    sqlconn.Open();

                    SqlCommand sqlcommand = new SqlCommand(sql, sqlconn);
                    sqlcommand.ExecuteNonQuery();
                    sqlconn.Close();
                }
            }
        }

2,通過adapter入庫,這種入庫,起先,你需要先把datatable放入到dataset中然后進行入庫,這種方式主要是對庫中對應的表進行增刪改,方便使用(效率只比第一種方式好點)

/// <summary>
        /// 通過adapter更新數(shù)據(jù)庫
        /// </summary>
        /// <param name="dataset"></param>
        public static void DataadapterInssert(DataSet dataset)
        {
            if (dataset.Tables.Count > 0)
            {
                foreach (DataTable itemTable in dataset.Tables)
                {
                    SqlCommand insertcommand = new SqlCommand("if exists(select * from " + itemTable.TableName + " where ENG = @ENG) begin return; end "+
                                      " else begin INSERT INTO " + itemTable.TableName + "([ENG],[GB],[B5],[FILE],[MSG])" +
                                      "VALUES(@ENG, @GB,@B5,@FILE,@MSG) end", new SqlConnection(connectString));
                    insertcommand.Parameters.Add("@ENG", SqlDbType.VarChar, 100, "ENG");
                    insertcommand.Parameters.Add("@GB", SqlDbType.VarChar, 100, "GB");
                    insertcommand.Parameters.Add("@B5", SqlDbType.VarChar, 200, "B5");
                    insertcommand.Parameters.Add("@FILE", SqlDbType.VarChar, 200, "FILE");
                    insertcommand.Parameters.Add("@MSG", SqlDbType.VarChar, 100, "MSG");

                    SqlDataAdapter sqldataadapter = new SqlDataAdapter();
                    sqldataadapter.InsertCommand = insertcommand;

                    sqldataadapter.Update(dataset, itemTable.TableName);
                }
            }
            
        }

3,重頭戲都在最后,這種方式速度比前兩種快很多,適合用于大量數(shù)據(jù)插入更新,也將datatable放入dataset中然后通過遍歷,將datatable復制到數(shù)據(jù)庫中對應的表中,快速便捷

// <summary>
        /// 通過SqlBulkCopy復制table數(shù)據(jù)到數(shù)據(jù)庫
        /// </summary>
        /// <param name="dataset"></param>
        public static void SqlbulkcopyInsert(DataSet dataset)
        {
            string ie;
            if (dataset.Tables.Count > 0)
            {
                foreach (DataTable itemTable in dataset.Tables)
                {
                    SqlBulkCopy sqlbulkcopy = new SqlBulkCopy(connectString, SqlBulkCopyOptions.UseInternalTransaction);
                    sqlbulkcopy.DestinationTableName = itemTable.TableName;//數(shù)據(jù)庫中的表名
                    for (int i = 0; i < itemTable.Rows.Count; i++)
                    {
                        ie = itemTable.Rows[i][2].ToString();
                    }
                    sqlbulkcopy.WriteToServer(itemTable);
                }
            }
            
        }

到此這篇關于C#使用Datatable導入sqlserver數(shù)據(jù)庫的三種方法的文章就介紹到這了,更多相關C# Datatable導入sql內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家! 

相關文章

  • C#實現(xiàn)的UDP收發(fā)請求工具類實例

    C#實現(xiàn)的UDP收發(fā)請求工具類實例

    這篇文章主要介紹了C#實現(xiàn)的UDP收發(fā)請求工具類,結合具體實例形式分析了C#針對UDP請求的監(jiān)聽、接收、發(fā)送等相關操作技巧,需要的朋友可以參考下
    2017-06-06
  • 在類庫或winform項目中打開另一個winform項目窗體的方法

    在類庫或winform項目中打開另一個winform項目窗體的方法

    這篇文章主要介紹了在類庫或winform項目中打開另一個winform項目窗體的方法,可以實現(xiàn)Winform項目間窗體的調用,在進行Winform項目開發(fā)中非常具有實用價值,需要的朋友可以參考下
    2014-11-11
  • C#實現(xiàn)圖片放大功能的按照像素放大圖像方法

    C#實現(xiàn)圖片放大功能的按照像素放大圖像方法

    這篇文章主要介紹了C#實現(xiàn)圖片放大功能的按照像素放大圖像方法,功能非常實用,需要的朋友可以參考下
    2014-07-07
  • C# 利用Aspose.Words.dll將 Word 轉成PDF

    C# 利用Aspose.Words.dll將 Word 轉成PDF

    關于word轉成pdf的方法網上有很多。大部分需要借助office 2007及以上版本的組件。安裝配置起來比較麻煩。今天偶然得之“Aspose.Words.dll”可以實現(xiàn)
    2013-08-08
  • C#學習筆記整理-迭代器模式介紹

    C#學習筆記整理-迭代器模式介紹

    下面小編就為大家分享一篇C#學習筆記整理-迭代器模式介紹,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • 使用C#開發(fā)ActiveX控件

    使用C#開發(fā)ActiveX控件

    activex控件以前也叫做ole控件,它是微軟ie支持的一種軟件組件或對象,可以將其插入到web頁面中,實現(xiàn)在瀏覽器端執(zhí)行動態(tài)程序功能,以增強瀏覽器端的動態(tài)處理能力。通常activex控件都是用c++或vb語言開發(fā),本文介紹另一種方式,使用c#語言開發(fā)activex控件。
    2017-02-02
  • C#自定義音樂播放器進度條

    C#自定義音樂播放器進度條

    這篇文章主要為大家詳細介紹了C#自定義音樂播放器進度條效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • C#表達式樹講解

    C#表達式樹講解

    本文詳細講解了C#表達式樹的創(chuàng)建、生成和使用,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • C#的Socket實現(xiàn)UDP協(xié)議通信示例代碼

    C#的Socket實現(xiàn)UDP協(xié)議通信示例代碼

    本篇文章主要介紹了C#的Socket實現(xiàn)UDP協(xié)議通信示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-01-01
  • C#實現(xiàn)在服務器端裁剪圖片的方法

    C#實現(xiàn)在服務器端裁剪圖片的方法

    這篇文章主要介紹了C#實現(xiàn)在服務器端裁剪圖片的方法,涉及C#操作圖片的相關技巧,需要的朋友可以參考下
    2015-04-04

最新評論