詳解C#把DataTable中數(shù)據(jù)一次插入數(shù)據(jù)庫(kù)的方法
現(xiàn)在實(shí)際的情況是這樣的:
客戶(hù)有一臺(tái)打卡機(jī),員工打卡的信息全部?jī)?chǔ)存在打卡機(jī)的Access數(shù)據(jù)庫(kù)里面,現(xiàn)在客戶(hù)引入了一種新的管理系統(tǒng),需要將Access數(shù)據(jù)庫(kù)中的打卡數(shù)據(jù)同步到SQL Server數(shù)據(jù)庫(kù)中,由于時(shí)間比較久,數(shù)據(jù)積累了有40多萬(wàn)條。
軟件功能:
選擇Access數(shù)據(jù)庫(kù)文件,填入目標(biāo)SQL Server數(shù)據(jù)庫(kù)的IP地址,然后開(kāi)始進(jìn)行同步。
實(shí)現(xiàn)方法:
1、先把Access數(shù)據(jù)庫(kù)中要導(dǎo)入的數(shù)據(jù)存入DataTable中
配置文件中的數(shù)據(jù)庫(kù)連接字符串
<connectionStrings> <add name="oleConStr" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="/> <add name="sqlConStr" connectionString ="server=tiantiankaixing;database=新建數(shù)據(jù)庫(kù);trusted_connection=sspi"/> </connectionStrings>
封裝讀取Access數(shù)據(jù)庫(kù)數(shù)據(jù)到DataTable中的方法
public static string OleConStr = ConfigurationManager.ConnectionStrings["oleConStr"].ConnectionString ; public static DataTable OleGetDataTable(string sql, string filePath) { string a = OleConStr + filePath; using (OleDbConnection conn = new OleDbConnection(a)) { using (OleDbDataAdapter da = new OleDbDataAdapter(sql, conn)) { try { conn.Open(); DataTable dt = new DataTable(); da.Fill(dt); return dt; } catch (Exception ex) { throw ex; } finally { if (conn.State == ConnectionState.Open) conn.Close(); } } } }
讀取目標(biāo)Access數(shù)據(jù)庫(kù)到Datatable
string sql = "select Id,Time from checkinout"; DataTable dt = AcHelper.OleGetDataTable(sql, @"F:\project\tiantiankaixing\admin.mdb");
2、封裝批量插入數(shù)據(jù)SQL Server數(shù)據(jù)的方法
public static void DataTableToSQLServer(DataTable dt,string connectString) { string connectionString = connectString; using (SqlConnection destinationConnection = new SqlConnection(connectionString)) { destinationConnection.Open(); using (SqlBulkCopy bulkCopy = new SqlBulkCopy(destinationConnection)) { try { bulkCopy.DestinationTableName = "checkinout";//要插入的表的表名 bulkCopy.BatchSize = dt.Rows.Count; bulkCopy.ColumnMappings.Add("ID", "ID");//映射字段名 DataTable列名 ,數(shù)據(jù)庫(kù) 對(duì)應(yīng)的列名 bulkCopy.ColumnMappings.Add("TIME", "TIME"); bulkCopy.WriteToServer(dt); System.Windows.Forms.MessageBox.Show("插入成功"); } catch (Exception ex) { Console.WriteLine(ex.Message); } finally { } } } }
3、調(diào)用DataTableToSQlServer()方法
string localCon = "server=tiantiankaixing;database=Test;trusted_connection=sspi"; Entity.DataTableToSQLServer(dt, localCon);
即可將DataTable中的全部數(shù)據(jù)插入數(shù)據(jù)庫(kù)
附:SqlBulkCopy的簡(jiǎn)單使用方法
public void Test() { string connectionString = "server=tiantiankaixing;database=新建數(shù)據(jù)庫(kù);trusted_connection=sspi"; using (SqlConnection sourceConnection = new SqlConnection(connectionString)) { sourceConnection.Open(); //獲取讀取的表總行數(shù) SqlCommand commandRowCount = new SqlCommand("select count(*) from student",sourceConnection); long countStart = System.Convert.ToInt32(commandRowCount.ExecuteScalar()); //使用SqlDataReader讀取源數(shù)據(jù) SqlCommand commandSourceData = new SqlCommand("select * from student", sourceConnection); SqlDataReader reader =commandSourceData.ExecuteReader(); //測(cè)試用,把數(shù)據(jù)從一個(gè)表批量插入到另一個(gè)表 //現(xiàn)實(shí)生活中肯定不會(huì) using (SqlConnection destinationConnection =new SqlConnection(connectionString)) { destinationConnection.Open(); //創(chuàng)建一個(gè)SQlBulkCopy對(duì)象 //指定目標(biāo)表名 //指定要插入的行數(shù) //指定對(duì)應(yīng)的映射 using (SqlBulkCopy bulkCopy =new SqlBulkCopy(destinationConnection)) { bulkCopy.DestinationTableName ="test"; bulkCopy.BatchSize = 1; bulkCopy.ColumnMappings.Add("數(shù)據(jù)源列名","目標(biāo)列名"); try { bulkCopy.WriteToServer(reader); } catch (Exception ex) { Console.WriteLine(ex.Message); } finally { reader.Close(); } } } } }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- C# 實(shí)現(xiàn)TXT文檔轉(zhuǎn)Table的示例代碼
- C# DataTable與Model互轉(zhuǎn)的示例代碼
- C# DataTable常見(jiàn)用法匯總
- C# ArrayList、HashSet、HashTable、List、Dictionary的區(qū)別詳解
- C#讀取Excel到DataTable的方法示例
- C#實(shí)現(xiàn)Json轉(zhuǎn)DataTable并導(dǎo)出Excel的方法示例
- C#使用Datatable導(dǎo)出Excel
- C#中DataTable 轉(zhuǎn)實(shí)體實(shí)例詳解
- C# 實(shí)現(xiàn)Table的Merge,Copy和Clone
相關(guān)文章
基于Silverlight DataGrid中無(wú)代碼設(shè)置開(kāi)始與結(jié)束日期DatePicker的實(shí)現(xiàn)方法
本篇文章是對(duì)Silverlight DataGrid中無(wú)代碼設(shè)置開(kāi)始與結(jié)束日期DatePicker的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05無(wú)法從 int? 轉(zhuǎn)換為 int 運(yùn)行時(shí)出現(xiàn)錯(cuò)誤
無(wú)法從"int?"轉(zhuǎn)換為"int" ,在運(yùn)行時(shí)會(huì)出現(xiàn)錯(cuò)誤,通過(guò)強(qiáng)制類(lèi)型轉(zhuǎn)換(int)便可解決2014-05-05C# WPF實(shí)現(xiàn)讀寫(xiě)CAN數(shù)據(jù)
這篇文章主要介紹了C# WPF實(shí)現(xiàn)讀寫(xiě)CAN數(shù)據(jù),文中通過(guò)代碼示例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-06-06Unity游戲開(kāi)發(fā)中的設(shè)計(jì)模式之策略模式
策略模式是Unity游戲開(kāi)發(fā)中常用的設(shè)計(jì)模式之一,用于封裝一系列算法或行為,并使這些算法或行為可以相互替換。通過(guò)策略模式,可以在運(yùn)行時(shí)動(dòng)態(tài)地選擇算法或行為,實(shí)現(xiàn)游戲中的多樣性和可擴(kuò)展性。常見(jiàn)的應(yīng)用包括AI行為、武器攻擊、移動(dòng)方式等2023-05-05C#實(shí)現(xiàn)簡(jiǎn)易的計(jì)算器
這篇文章主要為大家詳細(xì)介紹了C#實(shí)現(xiàn)簡(jiǎn)易的計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04C#入門(mén)之窗體的簡(jiǎn)單用法實(shí)例
這篇文章主要介紹了C#入門(mén)之窗體的簡(jiǎn)單用法,以實(shí)例形式分析了注冊(cè)頁(yè)面程序的實(shí)現(xiàn)過(guò)程,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12c# 獲得當(dāng)前絕對(duì)路徑的方法(超簡(jiǎn)單)
下面小編就為大家分享一篇c# 獲得當(dāng)前絕對(duì)路徑的方法(超簡(jiǎn)單),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-01-01