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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在類庫或winform項目中打開另一個winform項目窗體的方法
這篇文章主要介紹了在類庫或winform項目中打開另一個winform項目窗體的方法,可以實現(xiàn)Winform項目間窗體的調用,在進行Winform項目開發(fā)中非常具有實用價值,需要的朋友可以參考下2014-11-11C# 利用Aspose.Words.dll將 Word 轉成PDF
關于word轉成pdf的方法網上有很多。大部分需要借助office 2007及以上版本的組件。安裝配置起來比較麻煩。今天偶然得之“Aspose.Words.dll”可以實現(xiàn)2013-08-08C#的Socket實現(xiàn)UDP協(xié)議通信示例代碼
本篇文章主要介紹了C#的Socket實現(xiàn)UDP協(xié)議通信示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-01-01