ADO.Net的批量插入

转自http://www.csharpwin.com/csharpspace/12089r677.shtml

摘要:做大批量数据插入的时候,如果用Insert into ... values (...)这种方式的话效率极低,这里介绍两种性能比较好的批量插入方法。

在做大批量数据插入的时候,如果用Insert into ... values (...)这种方式的话效率极低,这里介绍两种性能比较好的批量插入方法。

1. 使用SqlBulkCopy

 

private static long SqlBulkCopyInsert()
{
Stopwatch stopwatch
= new Stopwatch();
stopwatch.Start();
DataTable dataTable
= GetTableSchema();

string passportKey;
for ( int i = 0 ; i < count; i ++ )
{
passportKey
= Guid.NewGuid().ToString();
DataRow dataRow
= dataTable.NewRow();
dataRow[
0 ] = passportKey;
dataTable.Rows.Add(dataRow);
}

SqlBulkCopy sqlBulkCopy
= new SqlBulkCopy(connectionString);
sqlBulkCopy.DestinationTableName
= " Passport " ;
sqlBulkCopy.BatchSize
= dataTable.Rows.Count;
SqlConnection sqlConnection
= new SqlConnection(connectionString);
sqlConnection.Open();

if (dataTable != null && dataTable.Rows.Count != 0 )
{
sqlBulkCopy.WriteToServer(dataTable);
}

sqlBulkCopy.Close();
sqlConnection.Close();
stopwatch.Stop();
return stopwatch.ElapsedMilliseconds;
}

 

使用SqlBulkCopy类进行数据插入其原理是采用了SQL Server的BCP协议进行数据的批量复制。这里我们先要建好一个DataTable(最好是通过DataAdapter来灌数据得到,因为这样出来的DataTable就已经有跟数据表相同的列定义,可以免去之后Mapping Column的步骤),把要插入的数据加进这个DataTable中,然后用SqlBulkCopy的实例来插入到数据库中。经过测试,SqlBulkCopy方法比直接用Sql语句插入数据的效率高出将近25倍。
 

 

2. 使用数据库中的Table类型变量实现数据插入
 

这种方法的前提是数据库中必须支持Table类型的变量。

 

Create Type PassportTableType as Table (PassportKey nvarchar ( 50 ))
Create PROCEDURE [ dbo ] . [ CreatePassportWithTVP ]
@TVP PassportTableType readonly
AS
BEGIN
SET NOCOUNT ON ;
Insert into Passport(PassportKey) select PassportKey from @TVP
END

 

private static long TVPInsert()
{
Stopwatch stopwatch
= new Stopwatch();
stopwatch.Start();
DataTable dataTable
= GetTableSchema();
string passportKey;
for ( int i = 0 ; i < count; i ++ )
{
passportKey
= Guid.NewGuid().ToString();
DataRow dataRow
= dataTable.NewRow();
dataRow[
0 ] = passportKey;
dataTable.Rows.Add(dataRow);
}

SqlParameter[] sqlParameter
=
{
new SqlParameter( " @TVP " , dataTable) };
SqlHelper.ExecuteNonQuery(connectionString,
CommandType.StoredProcedure,
" CreatePassportWithTVP " ,
sqlParameter);
stopwatch.Stop();
return stopwatch.ElapsedMilliseconds;
}

这种方法实现起来有点儿复杂。首先, 在数据库里新建一个自定义类型,继承Table类型的,然后建立Stored Procedure,将刚建立的自定义类型作为参数传入。关键点在这里了:使用insert into ... select ... from ...这个语句来实现批量插入。最后就剩下在ADO.Net中调用这个存储过程,将DataTable作为参数传入就大功告成了。
 

 

PS. 可能有人要说,DataAdapter不是提供了一个Update的方法,可以实现批量Insert、Delete、Update 的么?但其实DataAdapter的这种做法跟逐条逐条sql语句输入数据库然后执行没什么区别,甚至更慢。还是上面提供的这两种方法可以从根本上提升批量插入的性能。

转载于:https://www.cnblogs.com/yuerdongni/archive/2013/02/03/2890772.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值