SqlBulkCopy,微软提供的快速插入类,针对大批量数据操作,此类效果明显有所提升,以下是微软官方解释:

Microsoft SQL Server 提供一个称为 bcp 的流行的命令提示符实用工具,用于将数据从一个表移动到另一个表(表既可以在同一个服务器上,也可以在不同服务器上)。SqlBulkCopy 类允许编写提供类似功能的托管代码解决方案。还有其他将数据加载到 SQL Server 表的方法(例如 INSERT 语句),但相比之下 SqlBulkCopy 提供明显的性能优势。

使用 SqlBulkCopy 类只能向 SQL Server 表写入数据。但是,数据源不限于 SQL Server;可以使用任何数据源,只要数据可加载到 DataTable 实例或可使用 IDataReader 实例读取数据。

要使用此类一共需要用到三个步骤:

1.初始化数据源类型,DataTable或DataRow,一般我们使用数据库中的列名作为数据源的列名;

  1. DataTable dtCopy = new DataTable();
  2. dtCopy.Columns.Add("jhsSitid");
  3. dtCopy.Columns.Add("applyGoodsId");
  4. dtCopy.Columns.Add("ghsSitid");
  5. dtCopy.Columns.Add("state");
  6. dtCopy.Columns.Add("applyTime");

初始化DataTable

2.给数据源添加数据:

  1. foreach (DataRow r in ds.Tables[].Rows)
  2. {
  3. DataRow newRow = dtCopy.NewRow();
  4. newRow["jhsSitid"] = r["sitid"].ToString();
  5. newRow["applyGoodsId"] = goodsId;
  6. newRow["ghsSitid"] = siteId;
  7. newRow["state"] = "";
  8. newRow["applyTime"] = DateTime.Now;
  9. dtCopy.Rows.Add(newRow);
  10. }

循环获取数据源

3.打开数据库链接,批量插入数据源数据:

  1. SqlConnection conn = new SqlConnection(baseclass.connectionString);
  2. if (conn.State == ConnectionState.Closed)
  3. {
  4. conn.Open();
  5. }
  6. SqlTransaction st = conn.BeginTransaction();
  7. using (SqlBulkCopy sqlCopy = new SqlBulkCopy(conn, SqlBulkCopyOptions.FireTriggers, st))
  8. {
  9. sqlCopy.DestinationTableName = "jhqq_list";
  10. sqlCopy.BulkCopyTimeout = ;
  11. sqlCopy.ColumnMappings.Add("jhsSitId", "jhsSitId");
  12. sqlCopy.ColumnMappings.Add("applyGoodsId", "applyGoodsId");
  13. sqlCopy.ColumnMappings.Add("ghsSitId", "ghsSitId");
  14. sqlCopy.ColumnMappings.Add("state", "state");
  15. sqlCopy.ColumnMappings.Add("applyTime", "applyTime");
  16. try
  17. {
  18. sqlCopy.WriteToServer(dtCopy);
  19. st.Commit();
  20. result = true;
  21. }
  22. catch (Exception ex)
  23. {
  24. st.Rollback();
  25. }
  26. finally
  27. {
  28. conn.Close();
  29. }
  30. }

批量插入到数据库

sqlCopy.DestinationTableName-------->为指定数据库表名

sqlCopy.BulkCopyTimeout------------->指定完成时间

sqlCopy.ColumnMappings.Add--------->指定数据库与数据源中的对应关系

另外得注意的是,sqlCopy.ColumnMappings.Add指定对应关系时,一定要注意大小写要与数据库一直,sqlCopy.ColumnMappings.Add是对大小写很敏感的,另外对应的字段个数也必须一致,否则就会出现《给定的 ColumnMapping 与源或目标中的任意列均不匹配。》错误;

以上是个人见解,如有理解有误的地方欢迎指出;

SqlBulkCopy使用介绍以及注意事项的更多相关文章

  1. Windows Server 2012 NIC Teaming介绍及注意事项

    Windows Server 2012 NIC Teaming介绍及注意事项 转载自:http://www.it165.net/os/html/201303/4799.html Windows Ser ...

  2. Windows Server 2012 NIC Teaming 网卡绑定介绍及注意事项

    Windows Server 2012 NIC Teaming 网卡绑定介绍及注意事项 转载自:http://www.it165.net/os/html/201303/4799.html Window ...

  3. richface的配置、用法介绍和注意事项

    richface的配置.用法介绍和注意事项一.RichFaces (3.1.x) 技术需求 1.JDK 1.5 或更高版本: 2.支持的 JSF 实现: Sun JSF 1.1 RI - 1.2 My ...

  4. STC8H开发(四): FwLib_STC8 封装库的介绍和注意事项

    目录 STC8H开发(一): 在Keil5中配置和使用FwLib_STC8封装库(图文详解) STC8H开发(二): 在Linux VSCode中配置和使用FwLib_STC8封装库(图文详解) ST ...

  5. Excel 快速填充功能介绍以及注意事项

    快速填充 快速填充可以让我们以某种格式来填充单元格. 用"姓氏+职位"格式来快速地填充下面表格中第三列.在第一个单元格内输入"李书记",选中需要被填充的其他单元 ...

  6. NuGet程序包安装SQLite后完全抽离出SQLite之入门介绍及注意事项,你真的懂了吗?

    前言 近几天的几篇文章讲的内容非前面内容如系列的讲解,这几天文章都是我在项目中遇到的问题以及重新学习的知识,所以和大家分享一下,关于SQLite的文章多如牛毛,但是有些大多已经过时,为什么说过时,之前 ...

  7. c#中关于string的特性介绍以及注意事项

    前言 string类型在我们实际项目开发中是一个最使用的类型,string是一个引用类型这一点大家都知道,但是在实际使用过程中,大家会发现string和我们常见的引用类型使用还真不一样,看下面的一个简 ...

  8. 第七章 : Git 介绍 (下)[Learn Android Studio 汉化教程]

    Learn Android Studio 汉化教程 Let’s reset even further to remove all traces of your work on the deprecat ...

  9. STM32学习笔记 —— 0.1 Keil5安装和DAP仿真下载器配置的相关问题与注意事项

    Keil5安装的注意事项 安装细节在此不再做过多赘述,主要介绍一下注意事项: 安装路径中不能有中文. ARM的Keil的路径不能与51的Keil的有冲突,必须将目录分开. Keil5中不会自动添加芯片 ...

随机推荐

  1. SQL-SERVER2008登录错误233

    问题 : SQL Server2008在本地使用Windows身份验证登录或是使用SQL Server身份认证登录时报错:已成功与服务器建立连接,但是在登录过程中发生错取.(provider:共享内存 ...

  2. EffectiveC#8--确保0对于值类型数据是有效的(初始化问题)

    1.决不要创建一个不包括0在内的枚举类型 2.举例如下: public enum Planet { Mercury = 1, Venus = 2, Earth = 3, Mars = 4, Jupit ...

  3. 修改 “嗨加游-Prefix.pch” 或者 “嗨加游-Info.plist ” 方法

    如果要更改Info.plist与Prefix.pch文件实际路径,也就是实际文件的位置(不是在工程中的组织路径),需要到Build Settings中修改对应的配置,不然工程就找不到对应的Info.p ...

  4. UISwitch 监听响应

    UISwitch *swh = [[UISwitch alloc]initWithFrame:CGRectMake(100,100, 50, 30)];        swh.on = YES;    ...

  5. OAuth协议与第三方登录:(QQ,百度,微信,微博)

    OAuth 相当于授权的U盾,提供第三方认证的协议,是个安全相关的协议,作用在于,使用户授权第三方的应用程序访问用户的web资源,并且不需要向第三方应用程序透露自己的密码. 传统互联网:应用于PC端, ...

  6. Java IO5:管道流、对象流

    前言 前面的文章主要讲了文件字符输入流FileWriter.文件字符输出流FileReader.文件字节输出流FileOutputStream.文件字节输入流FileInputStream,这些都是常 ...

  7. poj1458 求最长公共子序列 经典DP

    Common Subsequence Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 45763   Accepted: 18 ...

  8. 自定义view组件

    参考<疯狂android讲义>第2版 2.1节P48,对应CustomViewDemo.zip. 若在开发过程中,发现现有的view均不能满足需要,可以自定义一个view. 自定义一个vi ...

  9. 基于jQuery UI的tabs选项卡美化

    很多朋友对JS望而生畏,但听很多朋友说jQuery很简单,因此开始使用jQuery,使用之后发现,只会写简单的功能,复杂的功能还是不太会写或者总是担心自己写的有性能问题,对前端人员来说只能通过不断学习 ...

  10. label的for属性与inputde的id元素绑定

    <form> <label for="male">Male</label> <input type="radio" n ...