服务器之家

服务器之家 > 正文

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

时间:2019-11-21 14:56     来源/作者:MSSQL教程网

按这个来算,我们那个发水票的时间就会由 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, CommandType.Text, "select * from Passport where 1=2").Tables[0]; 


相关文章

热门资讯

玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分
玄元剑仙肉身有什么用 玄元剑仙肉身境界等级划分 2019-06-21
男生常说24816是什么意思?女生说13579是什么意思?
男生常说24816是什么意思?女生说13579是什么意思? 2019-09-17
配置IIS网站web服务器的安全策略配置解决方案
配置IIS网站web服务器的安全策略配置解决方案 2019-05-23
Nginx服务器究竟是怎么执行PHP项目
Nginx服务器究竟是怎么执行PHP项目 2019-05-24
运维必须知道的关于云服务器的十个问题
运维必须知道的关于云服务器的十个问题 2019-05-24
返回顶部