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

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

一次往数据库  插入上万条数据。我用了 循环添加, 和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..

posted on   阿里正正  阅读(1110)  评论(0编辑  收藏  举报

编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示