首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >BulkCopy WriteToServer()插入错误的列

BulkCopy WriteToServer()插入错误的列
EN

Stack Overflow用户
提问于 2015-01-23 13:29:46
回答 2查看 2.2K关注 0票数 2

我正在尝试将DataTable写入Server上的目标表中。DataTable dt只包含一个列,其名为Email。我的目标表包含tpidlastnameagedateemail。这是我用于批量复制的代码:

代码语言:javascript
复制
using (SqlConnection sqlConn = new SqlConnection(sqlCs))
{
    sqlConn.Open();
    using (SqlBulkCopy bulkCopy = new SqlBulkCopy(sqlConn.ConnectionString, SqlBulkCopyOptions.KeepIdentity | SqlBulkCopyOptions.UseInternalTransaction))
    {
        bulkCopy.DestinationTableName = destinationTableName;
        bulkCopy.WriteToServer(dt);
    }
}

我看到的是,在我的目标表中,我从DataTable中获得电子邮件的值,该值被插入到tpid列中,而不是email。我在这里没有使用列映射,但不应该批量复制匹配电子邮件与电子邮件自动?

EN

回答 2

Stack Overflow用户

发布于 2015-01-23 13:36:13

考虑尝试这种映射:

代码语言:javascript
复制
SqlBulkCopyColumnMapping mapMAIL = new SqlBulkCopyColumnMapping("Email", "email");
bulkCopy.ColumnMappings.Add(mapMAIL);

如果需要,可以查询源表和目标表的MySQL架构,并根据字段名生成自动映射。

票数 6
EN

Stack Overflow用户

发布于 2015-01-23 13:51:05

不,不相配。您必须添加映射:

代码语言:javascript
复制
 myBulkCopy.ColumnMappings.Add(new SqlBulkCopyColumnMapping("Email", "email"));

或者源和目标以相同的顺序具有相同的列。如果需要更多的灵活性,我建议实现IDataReader并将其传递给WriteToServer方法。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28111022

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档