use*_*743 23 c# sql datatable sqlbulkcopy
我想知道如何在将数据添加到数据库之前将数据库表中的列映射到c#中的数据表.
using (SqlBulkCopy s = new SqlBulkCopy(conn))
{
s.DestinationTableName = destination;
s.WriteToServer(Ads_api_ReportData);
}
Run Code Online (Sandbox Code Playgroud)
Sta*_*ace 40
你可能需要一些东西
public void BatchBulkCopy(DataTable dataTable, string DestinationTbl, int batchSize)
{
// Get the DataTable
DataTable dtInsertRows = dataTable;
using (SqlBulkCopy sbc = new SqlBulkCopy(connectionString, SqlBulkCopyOptions.KeepIdentity))
{
sbc.DestinationTableName = DestinationTbl;
// Number of records to be processed in one go
sbc.BatchSize = batchSize;
// Add your column mappings here
sbc.ColumnMappings.Add("field1","field3");
sbc.ColumnMappings.Add("foo","bar");
// Finally write to server
sbc.WriteToServer(dtInsertRows);
}
}
Run Code Online (Sandbox Code Playgroud)
参考:如何使用SqlBulkCopyColumnMappingCollection? ..
Seel也是http://www.codeproject.com/Articles/18418/Transferring-Data-Using-SqlBulkCopy
Eva*_*n M 13
这成了一个常见的任务,我为它写了这个助手:
public static void AutoMapColumns(SqlBulkCopy sbc, DataTable dt)
{
foreach (DataColumn column in dt.Columns)
{
sbc.ColumnMappings.Add(column.ColumnName, column.ColumnName);
}
}
Run Code Online (Sandbox Code Playgroud)
自从我创建DataTable自己以来,我将其列命名为与SQL表相同.