哈哈,隔了一个星期,再怎么样都要发一篇,要多看书啊,书不能停~~~

  • 使用where子句进行过虑

  where子句的语法格式如下:where 过虑表达式

  例子:新建一个珠宝类,如下:

 class Jewellery
{
/// <summary>
/// 珠宝类型
/// <list type="Ring">戒指</list>
/// <list type="Necklace">项链</list>
/// <list type="Bracelet">手链</list>
/// </summary>
public enum JewelleryType
{
Ring,
Necklace,
Bracelet
}
/// <summary>
/// 当前珠宝状态
/// <list type="Stock">存货</list>
/// <list type="Repair">修理中</list>
/// <list type="Sold">已售出</list>
/// </summary>
public enum JewelleryState
{
Stock,
Repair,
Sold
}
public JewelleryType Type { get; set; }
public double Price { get; set; }
public JewelleryState State { get; set; }
}

  再我们使用一个List来做容器,通过LINQ来过虑。

 List<Jewellery> list = new List<Jewellery>()
{
new Jewellery() {Type=Jewellery.JewelleryType.Bracelet,State=Jewellery.JewelleryState.Repair,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Necklace,State=Jewellery.JewelleryState.Sold,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Ring,State=Jewellery.JewelleryState.Stock,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Necklace,State=Jewellery.JewelleryState.Sold,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Bracelet,State=Jewellery.JewelleryState.Stock,Price= },
new Jewellery() {Type=Jewellery.JewelleryType.Ring,State=Jewellery.JewelleryState.Repair,Price= }
}; //查找价格大于300的手链
var result = from item in list
where item.Price > && item.Type == Jewellery.JewelleryType.Bracelet
select item;
//转换为list.Where(item => item.Price > 300).Where(item => item.Type == Jewellery.JewelleryType.Bracelet);
Console.WriteLine(result.Count()); //记录当前正在修理中的珠宝总值
var result1 = (from item in list
where item.State == Jewellery.JewelleryState.Repair
select item).Sum(item => item.Price);
//转换为list.Where(item => item.State == Jewellery.JewelleryState.Repair).Sum(item => item.Price);
Console.WriteLine(result1); Console.ReadKey();
  • 退化的查询表达式
 var resutl2 = from item in list
select item;
//这个就是所谓的退化表达式,编译器会故意生成一个对Select方法的调用,即使它什么都没有做,但result2和list有很大的不同,
//两个序列返回的数据是相同的,但是Select方法的结果只是数据项的序列,而不是数据源本身。查询表达式的结果和源数据永远不会是同一个对象
//当有其它的操作的时候,就不用为编译器保留一个"空操作"Select子句
  • 使用orderby子句进行排序
 //按价格排序,从大到小
var resutl3 = from item in list
orderby item.Price descending
select item;
//转换为list.OrderByDescending(item => item.Price);
 //先用价格再按状态排序
var result4 = from item in list
orderby item.Price, item.State
select item;
  • let子句

  let子句只不过引入一个新的范围变量,它的值是基于其它范围变量,语法格式:let 标识符 = 表达式

 //货品是用RMB的,现在使用HK来记录,使用投影返回匿名对象的序列
var result5 = from item in list
let hk = item.Price / 0.8
select new { hk = hk, item = item };

  let操作符对一个表达式进行求值,并引入新的范围变量

  • 连接

  相应于数据库中的概念,使用两张表,这里是使用两个序列,通过匹配两者之间的数据行来创建结果。

  1. 使用join子句的内连接

  内连接涉及两个序列。一个键选择器表达式应用于第1个序列的每一个元素,另外一个键选择器(可能完全不同)应用于第二个序列的每一个元素。连接的结果是一个包含所有配对元素的序列,配对的规则是第1个元素的键与第2个元素的键相同。

  连接的格式:join 右边序列元素 in 右边序列

        on 左边序列元素的key equals 右边序列元素的key

 /// <summary>
/// 用于存放珠宝的盒子
/// </summary>
class Box
{
/// <summary>
/// 盒子有一个珠宝类型的属性,与要放的珠宝类型一致
/// </summary>
public Jewellery.JewelleryType jewelleryType { get; set; }
public string BoxName { get; set; }
}
 //打印每个珠宝存放的盒子,珠宝的状态要是存货
var result6 = from box in boxList
join item in list
on box.jewelleryType equals item.Type
where item.State == Jewellery.JewelleryState.Stock
select new { BoxName = box.BoxName, Price = item.Price }; result6.ToList().ForEach(item => Console.WriteLine("位置:" + item.BoxName + ";" + "价格:" + item.Price));

  结果如下

  可见在box1中放了一件价格为500的珠宝,在box3中放着一个价格为300的珠宝。这里作为两个序列的key的是珠宝的类型Jewellery.JewelleryType

  请斧正。

21.C#序列过虑、排序、let子句和连接(十一章11.3-11.5)的更多相关文章

  1. CPrimerPlus第十一章中的“选择排序算法”学习

    C Primer Plus第十一章字符串排序程序11.25中,涉及到“选择排序算法”,这也是找工作笔试或面试可能会遇到的题目,下面谈谈自己的理解. 举个例子:对数组num[5]={3,5,2,1,4} ...

  2. Hadoop阅读笔记(三)——深入MapReduce排序和单表连接

    继上篇了解了使用MapReduce计算平均数以及去重后,我们再来一探MapReduce在排序以及单表关联上的处理方法.在MapReduce系列的第一篇就有说过,MapReduce不仅是一种分布式的计算 ...

  3. 重排序列 & 拓扑排序

    http://bookshadow.com/weblog/2016/10/30/leetcode-sequence-reconstruction/ 这道题目,检查重排的序列是否一致. 用了拓扑排序. ...

  4. 【技术累积】【点】【java】【21】序列化二三事

    基础概念 把对象等转为二进制进行传输的是序列化,反之为反序列化: 应用场景一般为读写文件,传输数据/接口调用: Externalizable和Serializable java的序列化方式有两种: S ...

  5. 8大排序算法图文讲解 分类: Brush Mode 2014-08-18 11:49 78人阅读 评论(0) 收藏

    排序算法可以分为内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存. 常见的内部排序算法有:插入排序.希尔排序. ...

  6. 【字符串排序】n个数连接得到最小或最大的多位整数

    题目 描述:设有n个正整数,将它们依次连成在一排,组成一个多位数,现在要求可能组成的多位数中最大的多位数是什么? 例如:n=3时,3个整数13,312,343连成的最大多位数为:343-312-13. ...

  7. getDate() 获取时间 如2018年09月21日 11:32:11

    function p(s) { return s < 10 ? '0' + s: s;} function getDate() { var myDate = new Date(); //获取当前 ...

  8. MySQL-5.7.21非图形化下载、安装、连接问题记录

    1.安装包下载链接:https://cdn.mysql.com//Downloads/MySQL-5.7/mysql-5.7.21-winx64.zip 官网:https://www.mysql.co ...

  9. 21.centos7基础学习与积累-007-远程连接

    从头开始积累centos7系统运用 大牛博客:https://blog.51cto.com/yangrong/p5 IP地址: 互联网上的计算机 都会有一个唯一的32位的地址,ip地址,我们访问服务器 ...

随机推荐

  1. Hive权限控制和超级管理员的实现

    Hive权限控制 Hive权限机制: Hive从0.10可以通过元数据控制权限.但是Hive的权限控制并不是完全安全的.基本的授权方案的目的是防止用户不小心做了不合适的事情. 先决条件: 为了使用Hi ...

  2. xml in hadoop ETL with pig summary

    项目中需要把source为xml的文件通过flume放置到hdfs,然后通过MR导入到vertica中去,我之前做过简单的 尝试,是通过pig的piggybank的xmlloader然后Regex_e ...

  3. Hadoop 1.0 和 2.0 中的数据处理框架 - MapReduce

    1. MapReduce - 映射.化简编程模型 1.1 MapReduce 的概念 1.1.1 map 和 reduce 1.1.2 shufftle 和 排序 MapReduce 保证每个 red ...

  4. 我所理解的 惠普云 (HP Cloud)

    HP (惠普)于2014年5月27日宣布了它的新的云产品线 HP Helion,并宣布在接下来的两年时间内向该产品线投资10亿美金.应该说这是一笔很大的投入,充分显示了HP 在云这个领域的决心.本文试 ...

  5. shell script 学习笔记-----if,for,while,case语句

    1.if内的判断条件为逻辑运算: 2.if内的判断条件为目录是否存在,文件是否存在,下图先检验目录/home/monster是否存在,然后再检测/home/monster中的file.txt文件是否存 ...

  6. selenium遇到异常自动截图

    最近要在框架中添加case失败时,要自动截图,主要又两种方式,思想都是在抛异常的时候,捕获到异常,并作页面截图处理.今天坐下总结. 一.第一种方式,重写onException方法 只针对webdriv ...

  7. 【jQuery Demo】jQuery打造动态下滑菜单

    作者:漫凯维奇      来源:[教程]jQuery打造动态下滑菜单 Tip:这只是一个转载,源代码可以在上面的来源博文中下载 此教程将分步讲解如何使用JQuery和CSS打造一个炫酷动感菜单.效果如 ...

  8. C#委托与C语言函数指针及函数指针数组

    C#委托与C语言函数指针及函数指针数组 在使用C#时总会为委托而感到疑惑,但现在总新温习了一遍C语言后,才真正理解的委托. 其实委托就类似于C/C++里的函数指针,在函数传参时传递的是函数指针,在调用 ...

  9. Python天猫淘宝评论爬虫

    说明 由于Github 打包的exe某些文件上传被.gitignore了,所以不提供windows二进制包 https://github.com/hunterhug/taobaocomment 一个抓 ...

  10. 第22章 DLL注入和API拦截(2)

    22.4 使用远程线程来注入DLL 22.4.1 概述 (1)远程线程注入是指一个进程在另一个进程中创建线程,然后载入我们编写的DLL,并执行该DLL代码的技术.其基本思路是通过CreateRemot ...