• 数据库 一次插入几万条数据


    最近做了一个功能, 操作的数据量特别大,

    一次往数据库  插入上万条数据。我用了 循环添加, 和EF封装的添加功能。

    两次方式速度都非常慢,一万条数据要几分钟。

    在网上 查找资料后, 可以创建一个Datatable对象,然后把数据都赋值给这个Datatable对象的列。

    然后Copy到数据库就行了。

    下面这段代码是:实例化一个Datatable,  然后确定所有的列。列名最好于表里的字段一样哦

            然后循环你的 大数据,每次循环都创建一列,添加到Datatable。

     Datatable dt=new Datatable//创建Datatbel数据源 
      //确定DataTable字段的类型
      dt.Columns.Add("ProductID", typeof(int));
      dt.Columns.Add("TracingCode", typeof(string));
      dt.Columns.Add("Createtime", typeof(DateTime));
      
    //循环list数组, 每次循环,添加一行 //然后添加到DataTable里面 foreach (es_Tracing tracing in TracingList) {   DataRow dr = dt.NewRow();   dr["ProductID"] = tracing.ProductID;   dr["TracingCode"] = tracing.TracingCode;   dr["Createtime"] = tracing.Createtime;   dt.Rows.Add(dr); } 

    然后把这个dt  Copy到 指定表里面就行了

       string connectionString = ConfigurationManager.AppSettings["SqlCon"].ToString();
       SqlConnection connection = new SqlConnection(connectionString);//connection链接对象

      

      //实例化一个 SqlBulkCopy 对象
      using (SqlBulkCopy bulkCopy = new SqlBulkCopy(connectionString, SqlBulkCopyOptions.KeepIdentity | SqlBulkCopyOptions.UseInternalTransaction))
      {
             //目标表,
             bulkCopy.DestinationTableName = "dbo.[es_Tracing]";
             //数据源中的列名与目标表的属性的映射关系
             bulkCopy.ColumnMappings.Add("ProductID", "ProductID");
             bulkCopy.ColumnMappings.Add("TracingCode", "TracingCode");
             bulkCopy.ColumnMappings.Add("Createtime", "Createtime");
                         
             bulkCopy.WriteToServer(dt);//将数据源数据写入到目标表中
      }

    以上是我的 比较简洁的代码,可以自己封装哦。end..

  • 相关阅读:
    ASP.NET事件顺序
    Discuz!NT 代码阅读笔记(9)DNT数据库中唯一的用户函数解析
    Discuz!NT代码阅读笔记(2)网站安装自动化论坛程序安装及初始化过程
    ASP.NET网站和ASP.NET应用程序的区别
    根据日期获得当天是星期几/蔡勒(Zeller)公式
    Discuz!NT 代码阅读笔记(8)DNT的几个分页存储过程解析
    Excel导出数据报表的类
    MSDN Magazine的下载
    openSuSE 11.0正式版发布了
    用lighttpd+mono在Linux上面跑ASP.NET程序
  • 原文地址:https://www.cnblogs.com/liuzheng0612/p/11104418.html
Copyright © 2020-2023  润新知