linq语句查询执行的时机

第一步获取数据源

int [] obejct = new int[]{1,2,3,4,5,6,7,8,9}

第二步定义查询

var even = numbers.where(p=>p%2==0).select(p=>{Console.WritLine("HI")})

第三步执行查询

foreach(var item in even ){}

定义查询后,查询直到需要枚举结果是才被真正执行,这种方式称为“”延迟执行“”

当查询方法返回单一值时,查询立即执行

因此,可以通过以下技巧在定义=查询时就强制执行查询

查询语句与查询方法存在着紧密方法

1.CLR本身并不理解查询语句,它只理解查询方法

2.编译器负责在编译时将查询语句翻译为查询方法

3.大部分查询方法都有对应的查询语句形式,例如select()对应select

4.部分查询方法目前在C#中还没有对应的查询语句:

入Count()和Max()这时只能采用以下替代方案

查询方法

查询语句 + 查询方法的混合方法

5.一般情况下,建议使用可读性更好的查询语句

高级查询方法

聚合类

Count , Max/Min ,Average

 int[] arr = {11,21,3,4,5,6,7,8,9,10,11,12,155 };

            //高级查询方法 聚合类
Console.WriteLine("arr最大值" + arr.Max());
Console.WriteLine("arr最小值" + arr.Min());
Console.WriteLine("arr最平均值" + arr.Average());
Console.WriteLine("arr数组长度" + arr.Count());
Console.WriteLine("arr总和" + arr.Sum());

排序类

ThenBy

 int[] arr = {11,21,3,4,5,6,7,8,9,10,11,12,155 };
//排序类
var arr1 = arr.OrderBy(p => p.ToString().Substring(0, 1));

分区类

Take, TaKeWhile, SKip, SKipWhile

 int[] arr = {11,21,3,4,5,6,7,8,9,10,11,12,155 };
//二次排序
//var arr1 = arr.OrderBy(p => p.ToString().Substring(0, 1)).ThenBy(p => p);
//arr1.Print();
//var arr1 = arr.OrderBy(p => p.ToString().Substring(0, 1));//二次排序
//var arr2 = from i in arr1 orderby i descending select i;
//arr2.Print();

集合类

Distinct

//var arr1 = arr.Distinct();
//arr1.Print(); 去掉相同的属性

生成类

Range ,Repeat

  //生成类--静态类
//从10开始产生连续的50个数据
var arr1 = System.Linq.Enumerable.Range(10,50);
//生成重复的数据
var arr2 = System.Linq.Enumerable.Repeat(DateTime.Now,50);
arr1.Print();
arr2.Print();

遍历的拓展方法

 /// <summary>
/// 创建一个静态的类,拓展类
/// </summary>
public static class ExtraClass
{
/// <summary>
/// 拓展方法 必须是静态的
/// </summary>
/// <param name="s">对哪一个属性进行的拓展</param>
/// <returns></returns>
public static string ToPascal(this string s)
{
return s.Substring(0, 1).ToUpper() + s.Substring(1).ToLower();
}
//为IEnumerable提供输出方法
public static void Print(this IEnumerable ie)
{
IEnumerator IEU = ie.GetEnumerator();
while (IEU.MoveNext())
{
Console.WriteLine(IEU.Current);
}
} }

总结

和其他几类方法不同,Range/Repeat 不是扩展方法,而是普通的静态方法

Range只能产生整数序列

Repenat 可以产生泛型序列

所有的查询方法都存放在System.Linq.Enumerable静态类中

linQ学习笔记之三高级语句的更多相关文章

  1. matlab学习笔记9 高级绘图命令_2 图形的高级控制_视点控制和图形旋转_色图和颜色映像_光照和着色

    一起来学matlab-matlab学习笔记9 高级绘图命令_2 图形的高级控制_视点控制和图形旋转_色图和颜色映像_光照和着色 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考书籍 < ...

  2. matlab学习笔记9 高级绘图命令_1 图形对象_根对象,轴对象,用户控制对象,用户菜单对象

    一起来学matlab-matlab学习笔记9 高级绘图命令_1 图形对象_根对象,轴对象,用户控制对象,用户菜单对象 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考书籍 <matl ...

  3. Hadoop学习笔记(7) ——高级编程

    Hadoop学习笔记(7) ——高级编程 从前面的学习中,我们了解到了MapReduce整个过程需要经过以下几个步骤: 1.输入(input):将输入数据分成一个个split,并将split进一步拆成 ...

  4. 【SQL Server学习笔记】Delete 语句、Output 子句、Merge语句

    原文:[SQL Server学习笔记]Delete 语句.Output 子句.Merge语句 DELETE语句 --建表 select * into distribution from sys.obj ...

  5. linq学习笔记

    最近在学习linq的一些基础知识,看了c#高级编程及阅读了园子内部几篇优秀的博文,有所体会,感觉应该记录下来,作为以后复习使用.都是一些最基础的知识,大致分为三个部分:linq预备知识:linq查询: ...

  6. (转)Linq学习笔记

    写在前面 最近在看Linq,在博客园看到这篇文章,写的通俗易懂,转来和大家一起做个分享.原文地址http://www.cnblogs.com/goscan/archive/2011/05/05/Lin ...

  7. C#之Linq学习笔记【转】

    写在前面 其实在09年就已经学习过Linq了,并被她那优美的语法所吸引,只是现在所在的公司还在使用VS2005在.Net2.0的框架下面的开发,所以Linq也很久没有用过了,最近看部门的同事对这个有些 ...

  8. hive学习笔记之三:内部表和外部表

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  9. Django 学习笔记之三 数据库输入数据

    假设建立了django_blog项目,建立blog的app ,在models.py里面增加了Blog类,同步数据库,并且建立了对应的表.具体的参照Django 学习笔记之二的相关命令. 那么这篇主要介 ...

随机推荐

  1. 图解javascript

  2. 为什么要在游戏开发中使用ECS模式

    http://www.richardlord.net/blog/why-use-an-entity-framework Why use an entity system framework for g ...

  3. android studio 中移除module和恢复module

    一.移除Android Studio中module 在Android Studio中想要删除某个module时,在Android Studio中选中module,右键发现没有delete,如图: An ...

  4. iOS推送流程

    1. 在apple开发者帐号上创建一个BundleID,创建证书或者Xcode上都是用这个BundleID(例如com.mycompany.pushDemo) 2. 代码层面: 在capability ...

  5. c#委托----我的一点笔记

    public partial class ucBloodLabs { public delegate void ShowBloodEvent(); public ShowBloodEvent Show ...

  6. Binary Agents

    FCC题目: 传入二进制字符串,翻译成英语句子并返回. 二进制字符串是以空格分隔的. 示例: binaryAgent("01000001 01110010 01100101 01101110 ...

  7. SHELL编写NGINX服务控制脚本

    使用源码包安装的Nginx没办法使用"service nginx start"或"/etc/init.d/nginx start"进行操作和控制,所以写了以下的 ...

  8. 5 Django系列之通过list_display展示多对多与外键内容在admin-web界面下

    list_display展示多对多关系的内容 表结构关系 表一 class Server(models.Model): asset = models.OneToOneField('Asset') cr ...

  9. iconfont使用,亲测

    iconfont对于前端应用来说有很多便捷: 1.自由变化大小 2.自由修改颜色 3.可以添加一些视觉效果如:阴影.旋转.透明度. 4.兼容IE6 在线引用和下载到本地两种方法 一.在线引用 图标的制 ...

  10. History lives on in this distinguished Polish city 2017/1/4

    原文 History lives on in this distinguished Polish city Though it may be ancient. KraKow, Poland, is a ...