微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net 使用SqlBulkCopy极速插入数据到 SQL Server

感兴趣的小伙伴,下面一起跟随编程之家 jb51.cc的小编两巴掌来看看吧!

按这个来算,我们那个发水票的时间就会由 10分钟-->20秒,这可太神奇了。
于是乎,下demo,测试,改成自己一般使用的方法测试,NND,还真可以说是极速。
在此贴上我的Demo:sqlBulkcopy.rar

代码如下:

 
using System; 
using System.Diagnostics; 
using System.Data; 
using System.Data.sqlClient; 
using Microsoft.ApplicationBlocks.Data; 
namespace ConsoleAppInsertTest 
{ 
class Program 
{ 
static int count = 1000000; //插入的条数 
static void Main(string[] args) 
{ 
long sqlBulkcopyInsertRunTime = sqlBulkcopyInsert(); 
Console.WriteLine(string.Format(使用sqlBulkcopy插入{1}条数据所用的时间是{0}毫秒,sqlBulkcopyInsertRunTime,count)); 
long commonInsertRunTime = CommonInsert(); 
Console.WriteLine(string.Format(普通方式插入{1}条数据所用的时间是{0}毫秒,commonInsertRunTime,count)); 
Console.ReadKey(); 
} 
/// <summary> 
/// 使用普通插入数据 
/// </summary> 
/// <returns></returns> 
private static long CommonInsert() 
{ 
Stopwatch stopwatch = new Stopwatch(); 
stopwatch.Start(); 
for (int i = 0; i < count; i++) 
{ 
sqlHelper.ExecuteNonQuery(sqlHelper.sqlConnection,CommandType.Text,insert into passport(PassportKey) values(' + Guid.NewGuid() + ')); 
} 
stopwatch.Stop(); 
return stopwatch.ElapsedMilliseconds; 
} 
/// <summary> 
/// 使用sqlBulkcopy方式插入数据 
/// </summary> 
/// <returns></returns> 
private static long sqlBulkcopyInsert() 
{ 
Stopwatch stopwatch = new Stopwatch(); 
stopwatch.Start(); 
DataTable dataTable = GetTableSchema(); 
for (int i = 0; i < count; i++) 
{ 
DaTarow daTarow = dataTable.NewRow(); 
daTarow[2] = Guid.NewGuid(); 
dataTable.Rows.Add(daTarow); 
} 
//Console.WriteLine(stopwatch.ElapsedMilliseconds);//初始化数据时间 
sqlBulkcopy sqlBulkcopy = new sqlBulkcopy(sqlHelper.sqlConnection); 
sqlBulkcopy.DestinationTableName = Passport; 
if (dataTable != null && dataTable.Rows.Count != 0) 
{ 
sqlBulkcopy.WritetoServer(dataTable); 
} 
sqlBulkcopy.Close(); 
stopwatch.Stop(); 
return stopwatch.ElapsedMilliseconds; 
} 
private static DataTable GetTableSchema() 
{ 
return sqlHelper.ExecuteDataset(sqlHelper.sqlConnection,select * from Passport where 1=2).Tables[0]; 
} 
} 
} 

转自cnblogs的文章 sql批量插入数据几种方案的性能详细对比

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐