你的位置:首页 > ASP.net教程

[ASP.net教程]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源码