码迷,mamicode.com
首页 > 其他好文 > 详细

Linq的执行效率及优化

时间:2018-09-21 18:29:21      阅读:558      评论:0      收藏:0      [点我收藏+]

标签:ima   技术分享   art   执行   rest   lis   int   HERE   对比   

描述:项目中使用了linq,发现写的顺序不一样最后的结果也不一样,效率也不一样。

Linq的执行效率对比

List<int> source = new List<int>();
var rand = new Random();
int i = 5000;
while (i > 0)
{
    i--;
    source.Add(rand.Next(1, 500));
}

Stopwatch watch = new Stopwatch();

watch.Restart();
var temp2 = from s in source orderby s where s > 100 select s;
int count2 = temp2.Count();
watch.Stop();
Console.WriteLine("orderby s where s > 100: " + watch.ElapsedTicks);

watch.Restart();
var temp1 = from s in source where s > 100 orderby s select s;
int count = temp1.Count();
watch.Stop();
Console.WriteLine("where s > 100 orderby s: " + watch.ElapsedTicks);

效果如图:

技术分享图片

效率相差还是蛮大的,差不多10倍,所以linq的执行要按照一定的顺序,不能随心所欲。

Linq优化

linq和sql的语法差不多,所以可以按照sql的执行顺序对linq进行优化,建议顺序

1.FROM
2.WHERE
3.GROUP BY
4.HAVING
5.SELECT
6.DISTINCT
7.UNION
8.ORDER BY

 

Linq的执行效率及优化

标签:ima   技术分享   art   执行   rest   lis   int   HERE   对比   

原文地址:https://www.cnblogs.com/zhao123/p/9687799.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!