• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    asp.net 使用SqlBulkCopy极速插入数据到 SQL Server
    按这个来算,我们那个发水票的时间就会由 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批量复制数据到数据表
    上一篇:SQL SERVER 数据类型详解补充2
    下一篇:sql convert函数使用小结
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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