SqlBulkCopy块拷贝数据时,不履行触发器和束缚 解决办法

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 17:43   1235   0

在new SqlBulkCopy时,设置SqlBulkCopyOptions属性即可

SqlBulkCopy bulkCopy = new SqlBulkCopy(ConStr,SqlBulkCopyOptions.FireTriggers);

注意:函数重载问题:SqlBulkCopy一个参数时,第一个参数是sqlconnection,两个参数时第一个参数是sqlconnectionString.

SqlBulkCopyOptions属性:

Default对所有选项使用默认值。
KeepIdentity保留源标识值。如果未指定,则由目标分配标识值。
CheckConstraints请在插入数据的同时检查约束。默认情况下,不检查约束。
TableLock在批量复制操作期间获取批量更新锁。如果未指定,则使用行锁。
KeepNulls保留目标表中的空值,而不管默认值的设置如何。如果未指定,则空值将由默认值替换(如果适用)。
FireTriggers指定后,会导致服务器为插入到数据库中的行激发插入触发器。
UseInternalTransaction如果已指定,则每一批批量复制操作将在事务中发生。如果指示了此选项,并且为构造函数提供了 SqlTransaction 对象,则发生 ArgumentException

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP