首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >SqlBulkCopy的缺点是什么

SqlBulkCopy的缺点是什么
EN

Stack Overflow用户
提问于 2009-06-12 10:09:05
回答 2查看 7.1K关注 0票数 9

我曾经做过一些关于“用C#将大量数据插入数据库的最好方法”的研究,然后很多人建议我使用SqlBulkCopy。在我试过之后,它真的让我很惊讶。毫无疑问,SqlBulkCopy非常非常快。看起来SqlBulkCopy是插入数据(特别是大数据)的完美方式。但是为什么我们不一直使用它呢?使用SqlBulkCopy有什么缺点吗?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-06-12 11:38:45

我能想到两个原因:

  1. 据我所知,它仅适用于Microsoft SQL Server
  2. 在许多正常工作负载中,您不会执行批量insert,但偶尔会将insertselectupdate混合使用。微软自己表示,在Microsoft SQL Server上,使用普通insert会更有效

请注意,如果希望SqlBulkCopy等同于普通的插入,至少必须向其传递SqlBulkCopyOptions.CheckConstraints参数。

票数 10
EN

Stack Overflow用户

发布于 2010-07-28 02:59:27

也存在用于Oracle v11的SqlBulkCopy,但它是由安装Oracle时获得的Oracle .NET程序集提供的。SqlBulkCopy类基本上是由目标数据库引擎的提供者逐个实现的。

然而,一个巨大的缺点是绝对没有错误报告。例如,如果您更新了DataSet中的数据,使用适配器将其刷新回DB,并且存在键冲突(或任何其他故障),则罪魁祸首DataRows会将.HasErrors设置为true,您可以在引发异常消息时将其添加到异常消息中。

使用SqlBulkCopy,您只需获取错误的类型,仅此而已。祝你在调试时好运。

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

https://stackoverflow.com/questions/985968

复制
相关文章

相似问题

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