本篇文章主要介紹了詳解C#把DataTable中資料一次插入資料庫的方法,具有一定的參考價值,有興趣的可以瞭解一下。
現在實際的情況是這樣的:
客戶有一台打卡機,員工打卡的資訊全部儲存在打卡機的Access資料庫裡面,現在客戶引入了一種新的管理系統,需要將Access資料庫中的打卡資料同步到SQL Server資料庫中,由於時間比較久,資料積累了有40多萬條。
軟體功能:
選擇Access資料庫檔案,填入目標SQL Server資料庫的IP地址,然後開始進行同步。
實現方法:
1、先把Access資料庫中要匯入的資料存入DataTable中
設定檔中的資料庫連接字串
<connectionStrings> <add name="oleConStr" connectionString="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="/> <add name="sqlConStr" connectionString ="server=tiantiankaixing;database=建立資料庫;trusted_connection=sspi"/> </connectionStrings>
封裝讀取Access資料庫資料到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(); } } } }
讀取目標Access資料庫到Datatable
string sql = "select Id,Time from checkinout";DataTable dt = AcHelper.OleGetDataTable(sql, @"F:\project\tiantiankaixing\admin.mdb");
2、封裝批量插入資料SQL Server資料的方法
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列名 ,資料庫 對應的列名 bulkCopy.ColumnMappings.Add("TIME", "TIME"); bulkCopy.WriteToServer(dt); System.Windows.Forms.MessageBox.Show("插入成功"); } catch (Exception ex) { Console.WriteLine(ex.Message); } finally { } } } }
3、調用DataTableToSQlServer()方法
string localCon = "server=tiantiankaixing;database=Test;trusted_connection=sspi";Entity.DataTableToSQLServer(dt, localCon);
即可將DataTable中的全部資料插入資料庫
附:SqlBulkCopy的簡單使用方法
public void Test() { string connectionString = "server=tiantiankaixing;database=建立資料庫;trusted_connection=sspi"; using (SqlConnection sourceConnection = new SqlConnection(connectionString)) { sourceConnection.Open(); //擷取讀取的表總行數 SqlCommand commandRowCount = new SqlCommand("select count(*) from student",sourceConnection); long countStart = System.Convert.ToInt32(commandRowCount.ExecuteScalar()); //使用SqlDataReader讀取來源資料 SqlCommand commandSourceData = new SqlCommand("select * from student", sourceConnection); SqlDataReader reader =commandSourceData.ExecuteReader(); //測試用,把資料從一個表批量插入到另一個表 //現實生活中肯定不會 using (SqlConnection destinationConnection =new SqlConnection(connectionString)) { destinationConnection.Open(); //建立一個SQlBulkCopy對象 //指定目標表名 //指定要插入的行數 //指定對應的映射 using (SqlBulkCopy bulkCopy =new SqlBulkCopy(destinationConnection)) { bulkCopy.DestinationTableName ="test"; bulkCopy.BatchSize = 1; bulkCopy.ColumnMappings.Add("資料來源列名","目標列名"); try { bulkCopy.WriteToServer(reader); } catch (Exception ex) { Console.WriteLine(ex.Message); } finally { reader.Close(); } } } } }