作者:我不是老岑
在我现在所学的所有查询方式中就属Lambda最为简单便捷的。
我就先举一个例子来分析下:
比如:一个车库有很多的车,有自行车,有摩托车,有电动车,有汽车,它们停放得乱七八糟的,而我们要如何去每一种车归类呢?
我们先试一下最原始的的表达式
List 车库= (from tb车库 in myModel.车库
select new SelectVo
{
id = tb车库.车库的ID,
text = tb车库.车库的名称
}).ToList();
这是原始的方式
然后再试下linq的表达式
var list车库 = from tb in myModel.车库
select new
{
id = tb.车库的ID,
text = tb.车库的名称
};
Linq怎么比原始的的简单和便捷呢?
- 原始的要知道你要找的东西的全部名称才能找到,而linq只需要模糊就能搜索到
- 代码量比原始的代码量要少。
最后我们在试一下我们的重点lambda表达式
由于它是重点所以就把它的运算符要点也标识了一下(C#中的Lambda表达式使用Lambda运算符“=>”,该运算符读为“goes to”。语法:参数 => 表达式(方法体))
var list车库 = myModel.车库
.Select(a => new { id = a.车库的ID, text = a.车库的名称 });
这样看是不是觉得lambda表达式比以上两种方法更加简单和便捷呢?代码量也更少呢?
嗯嗯,确实,这三种表达式虽然不同,但是最后它们表达出来的意思是一样的,只不过lambda表达式看起来更加简单和便捷罢了。
有了上面的铺垫你们是不是对lambda表达式有了一定的了解,那我就把一些实例来展示一下吧!
这是只是部分的代码,但是是整体的构思。
var TabAchievement = from tbAchievement in myModel.PW_Achievement
group tbAchievement by tbAchievement.UserID into tbStudent
select new
{
UserID = tbStudent.Key,
AchievementID = tbStudent.OrderByDescending(m => m.Achievement).FirstOrDefault().AchievementID,
EligibleTypeID = tbStudent.OrderByDescending(m => m.Achievement).FirstOrDefault().EligibleTypeID,
ExamNumber = tbStudent.OrderByDescending(m => m.ExamNumber).FirstOrDefault().ExamNumber,
StTime = tbStudent.OrderByDescending(m => m.Achievement).ToList().FirstOrDefault().StTime,
EnTime = tbStudent.OrderByDescending(m => m.Achievement).ToList().FirstOrDefault().EnTime,
Achievement = tbStudent.OrderByDescending(m => m.Achievement).ToList().FirstOrDefault().Achievement
};
看代码是没有视觉感的,我们来看一下全部的代码的效果图吧。。。
这个饼状图是引用了layui的插件。
当然用其他两种表达式也能做出这种效果,但是没有这个简单便捷罢了,当然这只是我所学到中的最简单的方法。