.net Lambda表达式与Linq (LINQ TO object)
Linq To Object
public class Student
{
public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } public int ClassId { get; set; }
}
准备学生数据:
List<Student> stus= new List<Student> {
new Student(){Id=,Name="张三1",Age=,ClassId= },
new Student(){Id=,Name="张三2",Age=,ClassId= },
new Student(){Id=,Name="张三3",Age=,ClassId= },
new Student(){Id=,Name="张三4",Age=,ClassId= },
new Student(){Id=,Name="张三5",Age=,ClassId= },
new Student(){Id=,Name="张三6",Age=,ClassId=},
new Student(){Id=,Name="张三7",Age=,ClassId=},
new Student(){Id=,Name="张三8",Age=,ClassId=},
new Student(){Id=,Name="张三9",Age=,ClassId=},
new Student(){Id=,Name="李四",Age=,ClassId= },
new Student(){Id=,Name="李四1",Age=,ClassId= },
new Student(){Id=,Name="李四2",Age=,ClassId= },
new Student(){Id=,Name="李四3",Age=,ClassId= },
new Student(){Id=,Name="李四4",Age=,ClassId= },
new Student(){Id=,Name="李四5",Age=,ClassId= },
new Student(){Id=,Name="李四6",Age=,ClassId= },
new Student(){Id=,Name="李四7",Age=,ClassId= },
new Student(){Id=,Name="李四8",Age=,ClassId= },
new Student(){Id=,Name="王五",Age=,ClassId= },
new Student(){Id=,Name="王五1",Age=,ClassId= },
new Student(){Id=,Name="王五2",Age=,ClassId= },
new Student(){Id=,Name="王五3",Age=,ClassId= },
new Student(){Id=,Name="王五4",Age=,ClassId= },
new Student(){Id=,Name="王五5",Age=,ClassId= },
new Student(){Id=,Name="王五6",Age=,ClassId= },
new Student(){Id=,Name="王五7",Age=,ClassId= } };
查询班级Id是1的
var list = from s in stus
where s.ClassId ==
select new
{
Name = s.Name,
ClassId = s.ClassId
}; foreach (var item in list)
{
Console.WriteLine(item.Name + "---" + item.ClassId);
} //或者用框架的方法,查询年龄大于30的学生
Console.WriteLine("**********************");
var list1 = stus.Where(s => s.Age > ).Select(s => new { Id = s.Id, Name = s.Name, Age = s.Age });
foreach (var item in list1)
{
Console.WriteLine(item.Id + "---" + item.Name + "--" + item.Age);
}
下面写一个分页的Linq
var list = stus.Where(s => s.Age > )//条件筛选
.Select(s => new //投影
{
Name = s.Name,
Age = s.Age,
ClassId = s.ClassId
}).OrderBy(s => s.Age)//排序
.Skip()//跳过几条
.Take();//获取几条 ,用于分页 foreach (var item in list)
{
Console.WriteLine(item.Name + "--" + item.Age);
}
内连接,准备另外一个班级类
public class ClassInfo
{
public int Id { get; set; } public string ClassName { get; set; }
} List<ClassInfo> classes = new List<ClassInfo>()
{
new ClassInfo(){Id=,ClassName="初级班" },
new ClassInfo(){Id=,ClassName="中级班" },
new ClassInfo(){Id=,ClassName="高级班" },
// new ClassInfo(){Id=4,ClassName="超级班" },
};
var list = from s in stus
join cla in classes
on s.ClassId equals cla.Id select new
{
name = s.Name,
className = cla.ClassName,
age = s.Age
}; foreach (var item in list)
{
Console.WriteLine(item.name+"========"+item.className+"==="+item.age);
}
左外连接
var list1 = from s in stus
join c in classes
on s.ClassId equals c.Id
into slist
from sc in slist.DefaultIfEmpty()
select new
{
name = s.Name,
className = sc== null ? "没有班级":sc.ClassName,
age = s.Age
};
foreach (var item in list1)
{
Console.WriteLine(item.name + "========" + item.className + "===" + item.age);
}
.net Lambda表达式与Linq (LINQ TO object)的更多相关文章
- C#Lambda表达式演变和Linq的深度解析
Lambda 一.Lambda的演变 Lambda的演变,从下面的类中可以看出,.Net Framwork1.0时还是用方法实例化委托的,2.0的时候出现了匿名方法,3.0的时候出现了Lambda. ...
- 思考一个关于Lambda表达式做为linq条件的问题
有一个集合如下 List<User> users = new List<User> { new User{Name = "1",Aget = 12}, ne ...
- LINQ to Objects系列(3)深入理解Lambda表达式
Lambda表达式是学好LINQ很重要的一个知识点,后面的LINQ查询中会大量地使用到Lambda表达式.这篇文章从以下几点进行总结. 1,Lambda表达式的前世今生 2,Lambda表达式的实际运 ...
- 动态LINQ(Lambda表达式)构建
using System; using System.Collections.Generic; using System.Linq; using System.Linq.Expressions; us ...
- Lambda 表达式[MSDN]
Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地函数.Lambda 表达式对于编写 LINQ 查 ...
- 初探Lambda表达式
简单例子 Expression<Func<; 了解Net方法,没有比IL来得更加容易.反编译IL代码如下(截取部分显示) [] <<int32, bool>> ex ...
- C#中的Lambda表达式和表达式树
在C# 2.0中,通过方法组转换和匿名方法,使委托的实现得到了极大的简化.但是,匿名方法仍然有些臃肿,而且当代码中充满了匿名方法的时候,可读性可能就会受到影响.C# 3.0中出现的Lambda表达式在 ...
- Lambda 表达式(C# 编程指南) 微软microsoft官方说明
Visual Studio 2013 其他版本 Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地 ...
- C# IEnumerable,Lambda表达式和 Parallel并行编程的用法
以前一直主要做C++和C方面的项目,对C#不太了解熟悉,但听说不难,也就一直没有在意学习C#方面的知识.今天有个C#项目,需要做些应用的扩展,同时修改一些bug.但看了C#代码,顿时觉得有些不适应了. ...
- Lambda表达式和表达式树
在C# 2.0中,通过方法组转换和匿名方法,使委托的实现得到了极大的简化.但是,匿名方法仍然有些臃肿,而且当代码中充满了匿名方法的时候,可读性可能就会受到影响.C# 3.0中出现的Lambda表达式在 ...
随机推荐
- LESS的简单介绍
对于一些布局和样式比较复杂的网页,如何构建一个健康.优雅的CSS文件是一个很令人苦恼的问题.在书写静态页面的时候,我总是遇到布局结构累赘和重复样式复用性不高的问题,当然,对于这些问题归根究底还是要多联 ...
- 可能是史上最全的机器学习和Python(包括数学)速查表
新手学习机器学习很难,就是收集资料也很费劲.所幸Robbie Allen从不同来源收集了目前最全的有关机器学习.Python和相关数学知识的速查表大全.强烈建议收藏! 机器学习有很多方面. 当我开始刷 ...
- jmeter接口测试报java.net.SocketException: Socket closed错误。
如题,jmeter报出java.net.SocketException: Socket closed,我查询了下,服务器是正常的,可以返回数据,基本确定问题出在我这边jmeter.查询原因,看到有人说 ...
- mysql为何不支持开窗函数?
引用 在开窗函数出现之前存在着非常多用 SQL 语句非常难解决的问题,非常多都要通过复杂的相关子查询或者存储过程来完毕.为了解决这些问题,在2003年ISO SQL标准增加了开窗函数,开窗函数的使用使 ...
- cmd登录远程Oracle数据库
在cmd中输入 user/password@Ip:port/sid 例如: laoda/123@192.168.4.161:1521/orcl laoda是用户名,123是密码.
- PCA的数学原理(转)
PCA(Principal Component Analysis)是一种常用的数据分析方法.PCA通过线性变换将原始数据变换为一组各维度线性无关的表示,可用于提取数据的主要特征分量,常用于高维数据的降 ...
- Lsyncd - 实时文件同步工具(精译)
原文: http://axkibe.github.io/lsyncd/ 描述 Lsyncd监视本地目录树事件监视器接口(inotify或fsevents).它聚集并组合事件几秒钟,然后生成一个(或多个 ...
- 【数据结构】B-Tree, B+Tree, B*树介绍
[摘要] 最近在看Mysql的存储引擎中索引的优化,神马是索引,支持啥索引.全是浮云,目前Mysql的MyISAM和InnoDB都支持B-Tree索引,InnoDB还支持B+Tree索引,Memory ...
- Jmeter运行后出现乱码
1.响应结果出现乱码一般是编码的问题,汉子乱码在编码处编码写成utf-8 2.如果还不行,对jmeter的文件进行修改.具体修改方法参考https://blog.csdn.net/liu5781821 ...
- 【Floyd】BZOJ1491: [NOI2007]社交网络
Description Solution n<=100自然联想Floyd 设两个数组d[n][n]存最短距离,t[n][n]存最短路径条数 更新d的时候顺便更新t,乘法原理 if(d[i][ ...