SqlBulkCopy实现大批量数据导入

 
 //自增列重新生成:SqlBulkCopy bc = new SqlBulkCopy(conn)
//自增列保留原值:SqlBulkCopy bc = new SqlBulkCopy(conn,SqlBulkCopyOptions.KeepIdentity)
 using(SqlBulkCopy sbc = new SqlBulkCopy(conn,SqlBulkCopyOptions.KeepIdentity))
 {
      sbc.DestinationTableName = tableName;
      foreach (string col in colList)
      {
          sbc.ColumnMappings.Add(col, col);
      }
     sbc.BulkCopyTimeout = 0;
     sbc.WriteToServer(dt);
 }

  SqlBulkCopy原理是采用了SQL Server的BCP协议进行数据的批量复制,结合使用事务,就我们的案例而言,大约每批800条是平衡点,性能比逐条插入提高了100多倍,并前面同样使用事务批量插入的案例性能提升了7倍以上。

个人网站:http://www.51pansou.com

.net视频下载:.net视频教程

.net源码下载:.net源码

posted @ 2016-04-10 12:41  docker_net  阅读(447)  评论(0编辑  收藏  举报