var list = new List<Model>
{
new Model { Id = , UserName = "张三", Password = "", Email = "zhang3@yoy.com"},
new Model { Id = , UserName = "李四", Password = "", Email = "li4@yoy.com"},
new Model { Id = , UserName = "王五", Password = "", Email = "wang5@yoy.com"},
new Model { Id = , UserName = "赵六", Password = "", Email = "zhao6@yoy.com"},
}; //Add():添加单个,新加的数据将会在列表的最末端
//直译:添加
list.Add(new Model { Id = , UserName = "孙七", Password = "", Email = "sun7@yoy.com"});
//AddRange():添加多个,新加的数据将会在列表的最末端
//直译:范围添加
list.AddRange(new List<Model>
{
new Model { Id = , UserName = "刘一", Password = "", Email = "liu1@yoy.com"},
new Model { Id = , UserName = "陈二", Password = "", Email = "chen2@yoy.com"},
});
//Insert():添加单个,新加的数据将会在指定的索引位置,用法与Add()类似
//InsertRange():添加多个,新加的数据将会在指定的索引位置,AddRange()类似
//能指定位置插入数据,但是开销要大于Add/AddRange,目标集合越大,开销就越大
list.Insert(, new Model { Id = , UserName = "周八", Password = "", Email = "zhou8@yoy.com" });
list.InsertRange(, new List<Model>
{
new Model { Id = , UserName = "吴九", Password = "", Email = "wu9@yoy.com"},
new Model { Id = , UserName = "郑十", Password = "", Email = "zheng10@yoy.com"},
}); //将集合转化为指定的类型
var enumerable = list.AsEnumerable();//IEnumerable<T>类型
var queryable = list.AsQueryable();//IQueryable<T>类型
//IEnumerable类型内存迭代,
//IQueryable类型表达式解析,语法树动态解析,延后查询
//AsQueryable()常用于存在不确定的查询条件之前 //Distinct():去重复,与sql中distinct相同,返回值为IEnumerable<T>类型
list = list.Distinct().ToList(); //ForEach():循环方法,括号中并非添加bool条件,而是进行操作
list.ForEach(f => f.Id += );
list.ForEach(f =>
{
if (f.Id == ) f.Password = "";
else f.Id -= ;
}); //Find():Find一类方法为Framework2.0时期的产物,现基本不用
var find = list.Find(f => f.Id == );
var findAll = list.FindAll(f => f.Id == ); //FirstOrDefault():第一个或者是默认值,返回值肯能为null
//Framework3.5时期的产物,运用范围更广,支持IEnemerable<T>,但速度比Find较慢
//First():与FirstOrDefault()用法相似,但不会返回null,而抛出异常
var first = list.First();
var firstOrDefault = list.FirstOrDefault();
//最后一个,原理同First()/FirstOrDefault()
var last = list.Last();
var lastOrDefault = list.LastOrDefault();
//唯一的一个,原理同First()/FirstOrDefault(),但如果出现重复数据,则抛异常
var single = list.Single(s => s.Id == );
var singleOrDefault = list.SingleOrDefault(s => s.Id == ); var newList = new List<NewModel>
{
new NewModel { UserId = , Address = "Address", CellPhone = "", Country = "中国"},
new NewModel { UserId = , Address = "Address", CellPhone = "", Country = "西班牙"},
new NewModel { UserId = , Address = "Address1", CellPhone = "", Country = "中国"},
new NewModel { UserId = , Address = "Address2", CellPhone = "", Country = "美国"},
};
//Join():关联,相当于sql中的inner join
//写法:第一集合.Join(第二集合,第一的关联值,第二的关联值,(第一集合名,第二集合名)=>查询结果)
//查询结果可自定义类型,返回值为IEnemerable<查询结果>
var joinInfo = list.Join(newList, l => l.Id, nl => nl.UserId, (l, nl) => new { l, nl }).ToList();
var joinLinq = (from l in list
join nl in newList on l.Id equals nl.UserId
select new { l, nl }).ToList(); //GroupBy():按照指定参数进行分组,返回值类型为IEnemerable<IGrouping<string,T>>
var groupInfo = newList.GroupBy(g => g.Country).ToList();
var groupLinq = (from nl in newList
group nl by nl.Country into nlGroup
select nlGroup); //GroupJoin():左关联,相当于sql中的left join后进行了一定的分组,等于主表.Join(子表.GroupBy())
//按照一定规律分组后进行关联,形成一对多的匿名类型,IEnemerable<{T1, IEnemerable<T2>}>
//写法与Join相同:第一集合.GroupJoin(第二集合,第一的关联值,第二的关联值,(第一集合名,第二集合名)=>查询结果)
//查询结果可自定义类型,返回值为IEnemerable<查询结果>
//第一集合为主集合,第二集合为子集合,子集合条数可能为0
var groupJoin = list.GroupJoin(newList, l => l.Id, g => g.UserId, (l, g) => new { l, g }).ToList();
var groupJoinLinq = (from l in list
join nl in newList on l.Id equals nl.UserId into g
select new { l, g }).ToList(); //DefaultIfEmpty():查询默认或空实体,返回值为IEnumerable<T>类型,常用于做关联
var defaultList = list.DefaultIfEmpty().ToList(); //左关联变形:Join()/GroupJoin()加DefaultIfEmpty()方法实现
//先将两集合进行GroupJoin(),之后将查询结果中的子集合DefaultIfEmpty()
//注:此处的做关联与sql中的左关联有所不同,此处的左关联为一对一或一对null
var leftJoin = list.GroupJoin(newList, l => l.Id, g => g.UserId, (l, g) => new { l, g = g.DefaultIfEmpty() }).ToList();
var leftLinq1 = (from l in list
join nl in newList on l.Id equals nl.UserId into g
select new { l, g = g.DefaultIfEmpty() });
var leftLinq2 = (from l in list
join nl in newList on l.Id equals nl.UserId into nlJoin
from g in nlJoin.DefaultIfEmpty()
select new { l, g }); //All():集合中的数据是否全部符合条件
//直译:全部
var trueAll = list.All(a => a.Id > );
var falseAll = list.All(a => a.Id > ); //Any():集合中是否含有符合条件的数据
//直译:存在
var trueAny = list.Any(a => a.Id == );
var falseAny = list.Any(a => a.Id == ); //Min()/Max():最小值/最大值
//筛选出指定值/指定算法为最小/最大的数据,返回单条
//可与左关联/排序等活用
var minList = list.Min(m => m.Id);
var maxList = list.Max(m => m.Email.Length); //OrderBy()/OrderByDescending():正序/逆序
//按照指定字段/指定算法进行正序/逆序的排序
//可与左关联、分页等活用
var orderBy = list.OrderBy(o => o.Id).ToList();
var orderByLinq = (from l in list
orderby l.Id
select l).ToList();
var orderByDesc = list.OrderByDescending(o => o.Email.Length);
var orderByDescLinq = (from l in list
orderby l.Email.Length descending
select l).ToList();
//Reverse():反转排序,List无法适用
var reverse = list.Where(w => true).Reverse().ToList(); //Select():将一个实体中的数据转为另一个实体
//返回值类型为:IEnumerable<T>
var select1 = list.Select(s => s.Id).ToList();//指定字段/值
var select2 = list.Select(s => new { s.UserName, UserEmail = s.Email }).ToList();//匿名类型
var select3 = list.Select(s => new UserInfo { UserId = s.Id, UserName = s.UserName, UserEmail = s.Email }).ToList();
var select1Linq = (from l in list
select l.Id).ToList();
var select2Linq = (from l in list
select new { l.UserName, UserEmail = l.Email }).ToList();
var select3Linq = (from l in list
select new UserInfo { UserId = l.Id, UserName = l.UserName, UserEmail = l.Email }).ToList();
//SelectMany():查询出指定实体中的指定子集
var selectMany = groupJoin.SelectMany(s => s.g).ToList();
var country1 = groupJoin.SelectMany(s => s.g).Select(s => s.Country).ToList();
var country2 = groupJoin.Select(s => s.g.Select(ss => ss.Country)).ToList(); //Skip():跳过指定个数,常用于分页等
var skip = select1.Skip();
//Take():获取指定个数,常用于分页等
var take = select1.Take();
//SkipWhile():跳过值,直到符合条件为止,按序跳过,当符合条件开始获取剩余的
//直译:跳过直到
var skipWhile1 = select1.SkipWhile(w => w < ).ToList();
var skipWhile2 = select1.SkipWhile(w => w == ).ToList();
//TakeWhile():获取值,直到符合条件为止,按序获取,从第一条获取,当不符合条件则跳出
//直译:获取直到
var takeWhile1 = select1.TakeWhile(w => w < ).ToList();
var takeWhile2 = select1.TakeWhile(w => w == ).ToList(); //Sum():求和,指定值的和,与sql中的功能相同
var sum = list.Sum(s => s.Id);
//Union():追加数据,与sql中的功能相同
var doubleList = select1.Union(skip).ToList();
//Where():查询条件,与sql中的功能相同
var where = select1.Where(w => w > ).ToList(); ; //删除指定数据
//Remove():删除指定数据,参数为数据类型
//RemoveAt():删除指定索引位置的数据
//RemoveRange():批量删除指定索引位置的数据(索引位置, 删除个数)
//RemoveAll():删除全部符合条件的数据
list.Remove(firstOrDefault);
list.RemoveAt();
list.RemoveRange(, );
list.RemoveAll(r => r.Id > ); var test = from l in list
join nl in newList on l.Id equals nl.UserId
let x = l.Password
select new { x, nl }; Console.ReadKey();

Lambda&Linq的更多相关文章

  1. [MVC4]ASP.NET MVC4+EF5(Lambda/Linq)读取数据

    继续上一节初始ASP.NET MVC4,继续深入学习,感受了一下微软的MVC4+EF5(EntityFramework5)框架的强大,能够高效的开发出网站应用开发系统,下面就看一下如何用MVC4+EF ...

  2. 分享一个递归无限级拼接Json的方法---ExtJs的TreePanel和TreeGrid均适用(Ef,Lambda,Linq,IQueryable,List)

    话不多说,先上实体类,如果你不是codefirst,就把它当成数据表结构. 下面是底层BaseDal获取数据的方法  (如果你没有Base类,直接写在你的DAL层和BLL层) 下面是BaseServi ...

  3. [转][MVC4]ASP.NET MVC4+EF5(Lambda/Linq)读取数据

    本文转自:https://blog.csdn.net/dingxiaowei2013/article/details/29405687 继续上一节初始ASP.NET MVC4,继续深入学习,感受了一下 ...

  4. 几种查询方法(lambda Linq Enumerable静态类方式)

    1.需要一个数据源类: using System; using System.Collections.Generic; namespace Linq { public class Student { ...

  5. C# Lambda && Linq

    Lambda表达式在C#3.0加入,它是一个匿名函数,可用于创建委托或者表达式树类型,运算符为=>,读作"goes to",=>左侧是变量,右侧是表达式,变量类型可以自 ...

  6. 有关 Lambda && linq练习 有待整理

    1. 查询Student表中的所有记录的Sname.Ssex和Class列.(select sname,ssex,class from student) Students.Select(s=> ...

  7. ASP.NET MVC4+EF5(Lambda/Linq)读取数据

    希望大家记住,这里讲的所有的知识点,不仅仅是了解了就可以了,还要会灵活用,一定要多思考,撑握其中的编程思想. 本文讲的是委托和事件,这两个词可能你早就耳熟能详,但你是否真正撑握了呢? 本系列讲的C#高 ...

  8. Lambda表达式动态拼接(备忘)

    EntityFramework动态组合Lambda表达式作为数据筛选条件,代替拼接SQL语句 分类: C# Lambda/Linq Entity Framework 2013-05-24 06:58 ...

  9. [c#菜鸟]lambda表达式

    what 一.定义 Lambda 表达式是一种可用于创建 委托 或 表达式目录树 类型的 匿名函数 .通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地函数.(微软) 理 ...

随机推荐

  1. 经典的GDB调试命令,包括查看变量,查看内存

    经典的GDB调试命令,包括查看变量,查看内存 在你调试程序时,当程序被停住时,你可以使用print命令(简写命令为p),或是同义命令inspect来查看当前程序的运行数据.print命令的格式是: p ...

  2. Qt Creator 中文乱码问题

    一. Qt 4 乱码问题 解决方案 1. 在Qt 中 快捷菜单选项功能中 Edit(编辑)  --> Select Encoding...(选择编码) 选择载入(显示)编码和储存编码,要解决中文 ...

  3. PHP学习方向-进阶2(三)

    实践篇 给定二维数组,根据某个字段排序 如何判断上传文件类型,如:仅允许 jpg 上传 不使用临时变量交换两个变量的值 $a=1; $b=2; => $a=2; $b=1; strtoupper ...

  4. Ac自动机基础题集合

    Ac_automaton的板子打熟以后发现碰到题不会做,而且还是比较纯的板子,只要改几处地方就可以,Ac_automation有许多优秀而fantasy的性质,下面粘几个题,来记录一下做题的心得. 1 ...

  5. SCI 计算机 数学相关期刊

    数学,电子通信,计算机类 出版地 收录库 刊名 刊期 ISSN 影响因子 中国大陆 SCI CHINESE SCIENCE BULLETIN<科学通报>(英文版) 半月刊 1001-653 ...

  6. 【Mail.Ru Cup 2018 Round 2 A】 Metro

    [链接] 我是链接,点我呀:) [题意] [题解] 1:一直往右走的情况. 2:中间某个地方中转 (不会出现超过1次的转弯. (如果超过了和1次是等价的 [代码] #include <bits/ ...

  7. Maven学习总结(5)——聚合与继承

    Maven学习总结(五)--聚合与继承 一.聚合 如果我们想一次构建多个项目模块,那我们就需要对多个项目模块进行聚合 1.1.聚合配置代码 <modules> <module> ...

  8. Linux系统自带服务罗列

    /ect/services 文件列出了系统详细的服务 红色字体为常用服务 acpid ACPI(全称 Advanced Configuration and Power Interface)服务是电源管 ...

  9. POJ 1416 Shredding Company 回溯搜索 DFS

    Shredding Company Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6173   Accepted: 3361 ...

  10. [bzoj1251]序列终结者_splay

    序列终结者 bzoj-1251 题目大意:给定一个长度为n的正整数序列,支持区间加,区间反转,查询区间最大值.所有元素开始都是0. 注释:$1\le n\le 5\cdot 10^4$,操作个数不多于 ...