我使用SqlBulkCopy将数据从C#中的两个DataTable复制到Server。这些表由ParentId关联。我已经将每个SqlBulkCopy的DataTable包装在一个事务中。我将将数据写入其中的Server表也将标识设置为Yes的ParentId。
我正在将父DataTable写入服务器
bulkCopy.WriteToServer(parentDataTable);现在,我希望能够使用Server中的新ParentId更新子数据表中的ParentId。但是,父数据表仍然具有原始ParentId,而不是Server ParentId。
如何在调用ParentId之后获得父数据表的SqlBulkCopy.WriteToServer?
发布于 2018-09-14 01:15:12
看看插入,如果使用它,就可以使用旧的ParentId插入到新表中(确保ParentId是插入查询的一部分--如果启用了SET选项,则不会失败)。
如果确实需要更改ParentId (例如,如果表中有现有数据),则需要在大容量插入之前进行更改,因此仍然需要设置identity_insert。如果您尝试在事后执行此操作,则会导致运气不佳,因为父表和子表之间的链接已经消失。
发布于 2018-09-14 03:48:31
您应该能够使用[ColumnMappings][1]对象的SqlBulkCopy属性映射任何您喜欢的列。
https://stackoverflow.com/questions/52323132
复制相似问题