欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

C#导出数据到excel如何提升性能

时间:2021-12-23 10:21:01|栏目:.NET代码|点击:

一,要提升性能,我们先要知道耗时的地方在哪里

1,数据库查询,

2,把数据组合成新集合循环嵌套太多

二,那我们怎么优化呢?

一,数据库查询,

1》,数据库查询:如果数据量小,我们可以用临时datatable,连表查询,,可是如果是连表都是千万级上亿数据,就不建议用连表

那这个时候该怎么办呢?

2》这个时候我们可以选择先单表查询,然后再循环体查询自己所要的其他关联数据,这个时候我们需要注意的点是什么?

3》减少数据库查询!!!!!!!!!这个是重点,那怎么减少呢?正常逻辑如下代码,可是数据量很耗性能

foreach (var item in listST)
{
  var sModel= GetModel(); //如果这个方法每次都查询一次数据库,会很耗性能!!!导致循环循环很慢!,即时使用缓存也会很慢
  item.name = sModel.name;
}

4》我们可以换一种思路,优化如下代码:

List<Student> listST = new List<Student>();
List<int> listInt = new List<int>();
int g = 0;
foreach (var item in listST)
{
  ////我们可以选择每两千条数据查询一次
  ////保存成一个集合
  if (g % 2000 == 0)
  {
     listST = GetList($"id in ({string.Join(",", listST.Skip(g).Take(2000).Select(m => m.id).Distinct().ToArray())})", 2000, 1, "name,Id");
  }
  var sModel = listST.FirstOrDefault(m => m.id == item.id);
  item.name = sModel.name;
  g++;
}

上一篇:c# 两个数组比较,将重复部分去掉,返回不重复部分的实现

栏    目:.NET代码

下一篇:c# 深拷贝与浅拷贝的区别分析及实例

本文标题:C#导出数据到excel如何提升性能

本文地址:http://www.codeinn.net/misctech/187808.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有