linQ学习笔记之三高级语句
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学习笔记之三高级语句的更多相关文章
- matlab学习笔记9 高级绘图命令_2 图形的高级控制_视点控制和图形旋转_色图和颜色映像_光照和着色
一起来学matlab-matlab学习笔记9 高级绘图命令_2 图形的高级控制_视点控制和图形旋转_色图和颜色映像_光照和着色 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考书籍 < ...
- matlab学习笔记9 高级绘图命令_1 图形对象_根对象,轴对象,用户控制对象,用户菜单对象
一起来学matlab-matlab学习笔记9 高级绘图命令_1 图形对象_根对象,轴对象,用户控制对象,用户菜单对象 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考书籍 <matl ...
- Hadoop学习笔记(7) ——高级编程
Hadoop学习笔记(7) ——高级编程 从前面的学习中,我们了解到了MapReduce整个过程需要经过以下几个步骤: 1.输入(input):将输入数据分成一个个split,并将split进一步拆成 ...
- 【SQL Server学习笔记】Delete 语句、Output 子句、Merge语句
原文:[SQL Server学习笔记]Delete 语句.Output 子句.Merge语句 DELETE语句 --建表 select * into distribution from sys.obj ...
- 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也很久没有用过了,最近看部门的同事对这个有些 ...
- hive学习笔记之三:内部表和外部表
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- Django 学习笔记之三 数据库输入数据
假设建立了django_blog项目,建立blog的app ,在models.py里面增加了Blog类,同步数据库,并且建立了对应的表.具体的参照Django 学习笔记之二的相关命令. 那么这篇主要介 ...
随机推荐
- 图解javascript
- 为什么要在游戏开发中使用ECS模式
http://www.richardlord.net/blog/why-use-an-entity-framework Why use an entity system framework for g ...
- android studio 中移除module和恢复module
一.移除Android Studio中module 在Android Studio中想要删除某个module时,在Android Studio中选中module,右键发现没有delete,如图: An ...
- iOS推送流程
1. 在apple开发者帐号上创建一个BundleID,创建证书或者Xcode上都是用这个BundleID(例如com.mycompany.pushDemo) 2. 代码层面: 在capability ...
- c#委托----我的一点笔记
public partial class ucBloodLabs { public delegate void ShowBloodEvent(); public ShowBloodEvent Show ...
- Binary Agents
FCC题目: 传入二进制字符串,翻译成英语句子并返回. 二进制字符串是以空格分隔的. 示例: binaryAgent("01000001 01110010 01100101 01101110 ...
- SHELL编写NGINX服务控制脚本
使用源码包安装的Nginx没办法使用"service nginx start"或"/etc/init.d/nginx start"进行操作和控制,所以写了以下的 ...
- 5 Django系列之通过list_display展示多对多与外键内容在admin-web界面下
list_display展示多对多关系的内容 表结构关系 表一 class Server(models.Model): asset = models.OneToOneField('Asset') cr ...
- iconfont使用,亲测
iconfont对于前端应用来说有很多便捷: 1.自由变化大小 2.自由修改颜色 3.可以添加一些视觉效果如:阴影.旋转.透明度. 4.兼容IE6 在线引用和下载到本地两种方法 一.在线引用 图标的制 ...
- 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 ...