首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SQLBulkCopy和事务

SQLBulkCopy和事务
EN

Stack Overflow用户
提问于 2018-09-13 23:41:09
回答 2查看 393关注 0票数 0

我使用SqlBulkCopy将数据从C#中的两个DataTable复制到Server。这些表由ParentId关联。我已经将每个SqlBulkCopyDataTable包装在一个事务中。我将将数据写入其中的Server表也将标识设置为Yes的ParentId

我正在将父DataTable写入服务器

代码语言:javascript
复制
bulkCopy.WriteToServer(parentDataTable);

现在,我希望能够使用Server中的新ParentId更新子数据表中的ParentId。但是,父数据表仍然具有原始ParentId,而不是Server ParentId

如何在调用ParentId之后获得父数据表的SqlBulkCopy.WriteToServer

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-09-14 01:15:12

看看插入,如果使用它,就可以使用旧的ParentId插入到新表中(确保ParentId是插入查询的一部分--如果启用了SET选项,则不会失败)。

如果确实需要更改ParentId (例如,如果表中有现有数据),则需要在大容量插入之前进行更改,因此仍然需要设置identity_insert。如果您尝试在事后执行此操作,则会导致运气不佳,因为父表和子表之间的链接已经消失。

票数 0
EN

Stack Overflow用户

发布于 2018-09-14 03:48:31

您应该能够使用[ColumnMappings][1]对象的SqlBulkCopy属性映射任何您喜欢的列。

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

https://stackoverflow.com/questions/52323132

复制
相关文章

相似问题

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