主页 > 知识库 > asp.net 使用SqlBulkCopy极速插入数据到 SQL Server

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

热门标签:小e电话机器人 百度地图标注改颜色 申请400电话在哪办理流程 一个导航软件能用几个地图标注点 外呼运营商线路收费 临沂智能电销机器人加盟哪家好 电销外呼有录音系统有哪些 镇江网路外呼系统供应商 贵州房产智能外呼系统供应商
按这个来算,我们那个发水票的时间就会由 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];
}
}
}

转自cnblogs的文章 SQL批量插入数据几种方案的性能详细对比
您可能感兴趣的文章:
  • 使用SqlBulkCopy时应注意Sqlserver表中使用缺省值的列
  • C#中使用ADOMD.NET查询多维数据集的实现方法
  • C#数据库操作类AccessHelper实例
  • C#利用Openxml读取Excel数据实例
  • C#百万数据查询出现超时问题的解决方法
  • C#使用DataSet Datatable更新数据库的三种实现方法
  • C#应用BindingSource实现数据同步的方法
  • C#将Sql数据保存到Excel文件中的方法
  • C#中遍历DataSet数据集对象实例
  • C#使用晚绑定来实现压缩Access数据库的方法
  • C# Oracle数据库操作类实例详解
  • C#使用SqlBulkCopy批量复制数据到数据表

标签:晋城 合肥 嘉兴 保定 三明 延边 澳门 日照

巨人网络通讯声明:本文标题《asp.net 使用SqlBulkCopy极速插入数据到 SQL Server》,本文关键词  asp.net,使用,SqlBulkCopy,极速,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《asp.net 使用SqlBulkCopy极速插入数据到 SQL Server》相关的同类信息!
  • 本页收集关于asp.net 使用SqlBulkCopy极速插入数据到 SQL Server的相关信息资讯供网民参考!
  • 推荐文章