使用SqlBulkCopy将DataTable中的列映射到SQL表

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表相同.

  • 我自己想出了这个方法,心想:“天哪,我真是个天才!” 所以我就来SO分享一下。你抢先了我的一拳! (2认同)

Hug*_*opp 6

知道如果源查询(或表)中的列和目标表具有相同的名称并且顺序完全相同,那么可能很有用,因此无需明确写出映射,因为SqlBulkCopy它将创建一个使用此默认顺序的默认映射.