C#入门经典(第6版)阅读笔记(第六篇)(LINQ)

第一篇 基础知识点

  • LINQ关键字
  • from 指定数据源和范围变量
  • where 根据布尔表达式(由逻辑与 或 等组成)从数据源中筛选元素
  • select 指定查询结果中的元素所具有的类型或表现形式
  • group 对对查询结果按照键值进行分组
  • into 提供一个标示符,它可以充当对 join group 或 select 子句结果的引用
  • orderby 对查询出的元素进行排序
  • join 按照两个指定匹配条件来联接俩个数据源
  • let 产生一个用于查询表达式中子表达式查询结果的范围变量
1.1 概述

LINQ的全称是Language Integrated Query,中文译成“语言集成查询”。LINQ作为一种查询技术,首先要解决数据源的封装,大致使用了三大组件来实现这个封装,分别是LINQ to Object、LINQ to ADO.NET、LINQ to XML。它们和.NET语言的关系如下:

1.2 组成

LINQ的查询由3基本部分组成:获取数据源,创建查询,执行查询。

            // 1,获取数据源
            List<int> numbers = new List<int>() { 5, 4, 1, 3, 9, 8, 6, 7, 2, 0 };

            // 2,创建查询
            var numQuery = from num in numbers
                           where num % 2 == 0
                           select num;

            // 3,执行查询
            foreach (var num in numQuery)
            {
                Console.WriteLine("{0,1}", num);
            }
完整的查询操作
1.3 样例

代码:

static void Main(string[] args)
        {
            //获取数据源
            string[] names = { "Alen", "Zhen", "Chen","Song", "Hel", "Ken", "Aln", "Zen", "Cen", "He", "Ke", };
            //创建查询
            var queryResults = from n in names where n.StartsWith("S") select n;
            Console.WriteLine("Names beginning with S:");
            //执行查询
            foreach (var item in queryResults)
            {
                Console.WriteLine(item);
            }
            Console.Write("Program finished,press Enter/Reurn to continue:");
            Console.ReadLine();
        }
执行结果

第二篇 语句使用方式

2.1 from子句

** 创建一个LINQ表达式必须要以from子句开头。**

2.1.1 单个form子句

样例:

 //获取数据
            string[] a = { "日本","德国","英国","美国","澳大利亚"};
            //创建查询,创建一个LINQ表达式必须要以from子句开头
            var myQuery = from n in a where n.IndexOf("国") > 0 select n;
            //执行查询
            foreach(var item in myQuery)
            {
                Console.WriteLine(item);
            }
            Console.ReadKey();

样例:(查询List<T>集合)
代码:

namespace LINQ查询1
{
    //定义一个信息类
    public class CustomerInfo
    {
        public string Name { get; set; }
        public int Age { get; set; }
        public string Tel { get; set; }
    }
    class Test02_LINQList
    {
        static void Main(string[] args)
        {
            //使用对象和集合的初始化器
            //获取数据源
            List<CustomerInfo> customers = new List<CustomerInfo>
        {
            new CustomerInfo{Name = "杨铁心",Age = 100,Tel = "12332112332"},
            new CustomerInfo{Name = "杨康", Age = 80,Tel = "45654546565"},
            new CustomerInfo{Name = "杨过", Age = 60,Tel = "89979879789"}
        };
            //创建查询
            var query = from CustomerInfo ci in customers
                        where ci.Age >= 80
                        select ci;
            //执行查询
            foreach (CustomerInfo ci in query)
            {
                Console.WriteLine("姓名:{0} 年龄:{1} 电话:{2}",ci.Name,ci.Age,ci.Tel);
            }
            Console.ReadKey();
        }
    }
}
运行结果
2.1.2 复合from子句

样例:
代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace LINQ查询1
{
    public class CustomerInfo1
    {
        public string Name { get; set; }
        public int Age { get; set; }
        public List<string> TelTable { get; set; }
    }
    class Test03_MultiFrom
    {
        static void Main(string[] args)
        {
            //获取数据源
            List<CustomerInfo1> customer = new List<CustomerInfo1>
            {
                new CustomerInfo1{Name = "郭啸天",Age = 100,TelTable = new List<string>{"123321","321123"}},
                new CustomerInfo1{Name = "郭靖",Age = 80,TelTable = new List<string>{"456654","654456"}},
                new CustomerInfo1{Name = "郭芙", Age = 60,TelTable = new List<string>{"789987","987789"}}
            };
            //创建查询
            var query = from CustomerInfo1 ci in customer
                        from tel in ci.TelTable
                        where tel.IndexOf("789987") > -1
                        select ci;
            //执行查询
            foreach (var item in query)
            {
                Console.WriteLine("姓名:{0} 年龄:{1}",item.Name,item.Age);
                foreach (var tel in item.TelTable)
                {
                    Console.WriteLine("电话:{0}",tel);
                }
            }
            Console.ReadKey();

        }
    }
}

2.2 where 语句
  • where子句的作用就是筛选元素,除了开始和结束位置, where子句几乎可以出现在LINQ表达式的任意位置。
  • 一个LINQ表达式中可以有where子句,也可以没有;可以有一个,可以有多个;
  • 多个where子句之间的关系相当于逻辑“与”,每个where子句可以包含1个或多个逻辑表达式,这些条件成为“谓词”,多个谓词之间用布尔运算符隔开,比如逻辑“与”用&&,逻辑“或”用||,而不是用SQL中的AND或OR。
    2.2.1 常见查询

2.2.2 自定义函数


2.2.3 动态谓词的筛选

2.3 select子句
2.3.1 输出查询结果
2.3.2 对查询结果进行投影

代码:

 public class MyCustomerInfo
    {
        public string Name { get; set; }
        public string Tel { get; set; }
    }
    class Test04_whereExpDemo
    {
        static void Main(string[] args)
        {
            //获取数据源
            List<CustomerInfo> clist = new List<CustomerInfo>
            {
                new CustomerInfo{Name = "李白",Age = 88,Tel = "123321"},
                new CustomerInfo{Name = "杜甫", Age = 77,Tel = "456654"},
                new CustomerInfo{Name = "白居易", Age = 66,Tel = "123321"}
            };
            //定义动态的谓词数组,这个数组应该由实际运行环境生成
            string[] names = {"李白","杜甫","辛弃疾" };
            //查询在给定谓词数组里存在的客户(创建查询)
            var query = from customer in clist
                        where customer.Age < 90
                        select new MyCustomerInfo { Name = customer.Name, Tel = customer.Tel };//类型转换   
            //执行查询
            foreach (var ci in query)
            {
                Console.WriteLine("姓名:{0} 电话:{1} 类型{2}",ci.Name,ci.Tel,ci.GetType().FullName);
            }

            Console.ReadKey();
        }
    }

个人认为就是利用select对查询结果做了一个类型转换。

2.4 Group 子句

按照语法的规定,LINQ表达式必须以from子句开头,以select或group子句结束,所以除了使用select子句外,也可以使用guoup子句来返回元素分组后的结果。group子句返回的是一个IGrouping<TKey,TElement>泛型接口的对象集合。

2.5 into 子句

into子句作为一个临时标识符,用于select,group,join子句中。


   into子句提供了一个临时标识符,它存储了into子句前面的查询内容,使它后面的子句可以方便的使用,对其进行再次查询,投影等操作。

2.6 排序子句

2.6.1 OrderBy和OrderByDescending

2.6.2 ThenBy和ThenByDescending

2.7 let 子句

let子句用于在LINQ表达式中存储子表达式的计算结果。let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它。此范围变量可以再后续的LINQ子句中使用。

2.8 join子句

如果一个数据源中元素的某个属性可以跟另一个数据源中元素的属性进行相等比较,那么这两个数据源可以用join子句进行关联。jion子句用equals关键字进行比较,而不是常见的==。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容