C#导出数据到excel如何提升性能
一,要提升性能,我们先要知道耗时的地方在哪里
1,数据库查询,
2,把数据组合成新集合循环嵌套太多
二,那我们怎么优化呢?
一,数据库查询,
1》,数据库查询:如果数据量小,我们可以用临时datatable,连表查询,,可是如果是连表都是千万级上亿数据,就不建议用连表
那这个时候该怎么办呢?
2》这个时候我们可以选择先单表查询,然后再循环体查询自己所要的其他关联数据,这个时候我们需要注意的点是什么?
3》减少数据库查询!!!!!!!!!这个是重点,那怎么减少呢?正常逻辑如下代码,可是数据量很耗性能
foreach(variteminlistST)
{
varsModel=GetModel();//如果这个方法每次都查询一次数据库,会很耗性能!!!导致循环循环很慢!,即时使用缓存也会很慢
item.name=sModel.name;
}
4》我们可以换一种思路,优化如下代码:
ListlistST=newList (); List listInt=newList (); intg=0; foreach(variteminlistST) { ////我们可以选择每两千条数据查询一次 ////保存成一个集合 if(g%2000==0) { listST=GetList($"idin({string.Join(",",listST.Skip(g).Take(2000).Select(m=>m.id).Distinct().ToArray())})",2000,1,"name,Id"); } varsModel=listST.FirstOrDefault(m=>m.id==item.id); item.name=sModel.name; g++; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
热门推荐
10 美好的成语祝福语简短
11 男生打球祝福语简短霸气
12 学院祝福语女生大全简短
13 三八简短祝福语给婆婆
14 结婚对白誓言简短祝福语
15 祝美术老师祝福语简短
16 简短朋友旅行祝福语大全
17 生日果酒祝福语简短独特
18 爱情寄语简短祝福语大全