C# Linq 学习笔记
刚刚学习了 Siki老师 的C#教程Linq部分,以下是笔记
需要引用命名空间
using System.Linq;
然后我们需要准备数据
武林高手类
/// <summary>
/// 武林高手类
/// </summary>
class MartialArtsMaster
{
public int ID { get; set; }
public string Name { get; set; }
public int Age { get; set; }
public string MenPai { get; set; }
public string Kongfu { get; set; }
public int Level { get; set; } public override string ToString()
{
return string.Format("{0}--{1}--{2}--{3}--{4}--{5}", ID, Name, Age, MenPai, Kongfu, Level);
}
}
武林绝学类
class Kongfu
{
public int ID { get; set; }
public string Name { get; set; }
public int Power { get; set; } public override string ToString()
{
return string.Format("{0}--{1}--{2}", ID, Name, Power);
}
}
Main方法里的武林高手列表和武林绝学列表
List<MartialArtsMaster> masterList = new List<MartialArtsMaster>()
{
new MartialArtsMaster() { ID = , Name = "黄蓉", Age = , MenPai = "丐帮", Kongfu = "打狗棒法", Level = },
new MartialArtsMaster() { ID = , Name = "洪七公", Age = , MenPai = "丐帮", Kongfu = "打狗棒法", Level = },
new MartialArtsMaster() { ID = , Name = "郭靖", Age = , MenPai = "丐帮", Kongfu = "降龙十八掌", Level = },
new MartialArtsMaster() { ID = , Name = "任我行", Age = , MenPai = "明教", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "东方不败", Age = , MenPai = "明教", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "林平之", Age = , MenPai = "华山", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "岳不群", Age = , MenPai = "华山", Kongfu = "葵花宝典", Level = },
new MartialArtsMaster() { ID = , Name = "令狐冲", Age = , MenPai = "华山", Kongfu = "独孤九剑", Level = },
new MartialArtsMaster() { ID = , Name = "梅超风", Age = , MenPai = "桃花岛", Kongfu = "九阴真经", Level = },
new MartialArtsMaster() { ID = , Name = "黄药师", Age = , MenPai = "梅花岛", Kongfu = "弹指神功", Level = },
new MartialArtsMaster() { ID = , Name = "风清扬", Age = , MenPai = "华山", Kongfu = "独孤九剑", Level = },
};
List<Kongfu> kongfuList = new List<Kongfu>()
{
new Kongfu() {ID=,Name="打狗棒法",Power= },
new Kongfu() {ID=,Name="降龙十八掌",Power= },
new Kongfu() {ID=,Name="葵花宝典",Power= },
new Kongfu() {ID=,Name="独孤九剑",Power= },
new Kongfu() {ID=,Name="九阴真经",Power= },
new Kongfu() {ID=,Name="弹指神功",Power= }
};
表达式基本写法
var res = from m in masterList
where m.MenPai == "丐帮"//条件,布尔表达式
select m.Name;//返回名字的集合
事实上,条件语句是可以用一个委托代替的,如下面的代码
delegate bool BoolDel(MartialArtsMaster mar);
var res = from m in masterList
where boolDel(m)
select m.Name;
也可以使用扩展方法的方式进行查询
var res = masterList.Where(new Func<MartialArtsMaster, bool>(boolDel));
接着我用下面的代码输出
Console.WriteLine("找到 " + res.Count() + " 条记录:");
foreach(var item in res)
{
Console.WriteLine(item);
}
联合查询
使用多个from in 进行查询
var res = from m in masterList
from k in kongfuList
where m.Kongfu == k.Name && k.Power >
select new { master = m, kongfu = k };
使用扩展方法进行联合查询
var res = masterList.SelectMany(m => kongfuList, (m, k) => new { master = m, kongfu = k })
.Where(x => x.master.Kongfu == x.kongfu.Name && x.kongfu.Power > );
使用Join on 进行联合查询
var res = from m in masterList
join k in kongfuList on m.Kongfu equals k.Name
select new { master = m, kongfu = k };
对查询结果进行排序
var res = from m in masterList
orderby m.Level, m.Age descending //级别升序,年龄降序
select m;
扩展方法形式
var res = masterList.OrderBy(m => m.Level).ThenByDescending(m => m.Age);
分组查询
var res = from k in kongfuList
join m in masterList on k.Name equals m.Kongfu
into groups//根据 k 分组
orderby groups.Count()
select new { kongfu = k, count = groups.Count() };
按照自身字段分组
var res = from m in masterList
group m by m.MenPai into g
select new { MenPai = g.Key, Count = g.Count() };
量词操作
其实就是查询这个集合里是否包含我要查的东西
Console.WriteLine(masterList.Any(m => m.MenPai == "少林寺"));//任一满足,则返回true
Console.WriteLine(masterList.All(m => m.MenPai == "丐帮"));//所有满足,则返回true
第一行查询武林高手列表里有没有少林寺的,第二行查询列表里的是不是都是丐帮的
C# Linq 学习笔记的更多相关文章
- linq学习笔记
最近在学习linq的一些基础知识,看了c#高级编程及阅读了园子内部几篇优秀的博文,有所体会,感觉应该记录下来,作为以后复习使用.都是一些最基础的知识,大致分为三个部分:linq预备知识:linq查询: ...
- (转)Linq学习笔记
写在前面 最近在看Linq,在博客园看到这篇文章,写的通俗易懂,转来和大家一起做个分享.原文地址http://www.cnblogs.com/goscan/archive/2011/05/05/Lin ...
- C#之Linq学习笔记【转】
写在前面 其实在09年就已经学习过Linq了,并被她那优美的语法所吸引,只是现在所在的公司还在使用VS2005在.Net2.0的框架下面的开发,所以Linq也很久没有用过了,最近看部门的同事对这个有些 ...
- C# LINQ学习笔记一:走进LINQ的世界
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5832322.html,记录一下学习过程以备后续查用. LINQ 简介: 语言集成查询(LINQ)是Vi ...
- LINQ 学习笔记(1)
学习资源参考 : http://www.cnblogs.com/lifepoem/archive/2011/12/16/2288017.html 常用方法是 Where, OrderBy, Selec ...
- C# LINQ学习笔记五:LINQ to XML
本笔记摘抄自:https://www.cnblogs.com/yaozhenfa/p/CSharp_Linq_For_Xml.html,记录一下学习过程以备后续查用. 一.生成xml 1.1创建简单的 ...
- C# LINQ学习笔记四:LINQ to OBJECT之操作文件目录
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5816051.html,记录一下学习过程以备后续查用. 许多文件系统操作实质上是查询,因此非常适合使用LINQ方 ...
- C# LINQ学习笔记三:LINQ to OBJECT之操作字符串
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5814204.html,记录一下学习过程以备后续查用. 一.统计单词在字符串中出现的次数 请注意,若要执行计数, ...
- C# LINQ学习笔记二:LINQ标准查询操作概述
本笔记摘抄自:https://www.cnblogs.com/liqingwen/p/5801249.html,记录一下学习过程以备后续查用. “标准查询运算符”是组成语言集成查询 (LINQ) 模式 ...
随机推荐
- Educational Codeforces Round 58
D. GCD Counting 题意: 给出n个点的树,每个点有一个权值,找出一条最长的路径使得路径上所有的点的gcd>1 题解: gcd>1的一定不会有很多.所以暴力搞一下就行,不需要点 ...
- pairs
pairs http://acm.hdu.edu.cn/showproblem.php?pid=5178 Time Limit: 2000/1000 MS (Java/Others) Memor ...
- Minimum Cost(最小费用最大流,好题)
Minimum Cost http://poj.org/problem?id=2516 Time Limit: 4000MS Memory Limit: 65536K Total Submissi ...
- .net使用httpHandler添加图片防盗链
.net使用httpHandler添加图片防盗链1. 配置web.config: <!--图片添加水印的配置--> <httpHandlers> <add verb=&q ...
- oracle 将逗号分隔的字符串转成多行记录
, rownum), length(, rownum, length(replace('a,b,c,d', ',', '')), length('a,b,c,d') from dual connect ...
- IaaS、PaaS、SaaS、CaaS、MaaS五者的区别
云计算构架图 很明显,这五者之间主要的区别在于第一个单词,而aaS都是as-a-service(即服务)的意思,这五个模式都是近年来兴起的,且这五者都是云计算的落地产品,所以我们先来 ...
- WEB服务器与应用服务器解疑
1.WEB服务器: 理解WEB服务器,首先你要理解什么是WEB?WEB你可以简单理解为你所看到的HTML页面就是WEB的数据元素,处理这些数据元素的应用软件就叫WEB服务器,如IIS.apache. ...
- dede的cfg_keywords和cfg_description无法显示
问题:在生成html文件时,网页的keywords和description的content为空,但后台显示这两项是有值的. 解决方案: 1.设置 系统->系统基本参数->站点根网址 设 ...
- php不重新编译,安装未安装过的扩展,如curl扩展
假设我们的之前的php安装于/data/php下. 1.找到之前安装的PHP源码包,把它重新解压出来,进入到要安装的扩展目录. > cd /data/php-5.6.11/ext/curl (* ...
- C#6.0新特性:var s = $"{12}+{23}={12+23}"
为什么会出现$符号,c#6.0才出现的新特性 var s = string.Fromat("{0}+{1}={2}",12,23,12+23) 用起来必须输入string.From ...