Linq 常用查询操作符

限定操作:

1. All:用来确定是否序列中的所有元素都满足条件

2. Any:用来确定序列是否包含任何元素,有参方式用来确定序列中是否有元素满足条件

3. Contains:方法用来确定序列是否包含满足指定条件的元素

排序:

1. OrderBy:将序列中的元素按照升序排列

2. ThenBy:实现按照次关键字对序列进行升序排列(二级排序)

3. OrderByDescending:将序列中的元素按照降序排列

4. ThenByDescending:实现按照次关键字对序列进行降序排列(二级排序)

5. Reverse:对集合反向排序

分区操作:
1. Skip:跳过集合的前n个元素
2. SkipWhile:直到某一条件成立就停止跳过
3. Take:获取集合的前n个元素
4. TakeWhile:直到某一条件成立就停止获取

聚合操作:
1. Aggregate:对集合值执行自定义聚合运算。例如:把所有值按某个符号间隔输出

2. Average:求集合中元素的平均值,返回值类型double

3. Count:求集合中元素的个数,返回值类型Int32

4. LongCount:求集合中元素的个数,返回值类型Int64

5. Max:求集合中元素的最大值

6. Min:求集合中元素的最小值

7. Sum:求集合中元素的和

集合操作:

1. Distinct:过滤集合中的相同项

2. Union:连接不同集合,自动过滤相同项

3. Concat:连接不同集合,不会自动过滤相同项

4. Intersect:获取不同集合的相同项(交集)

5. Except:从某集合中删除其与另一个集合中相同的项

6. SequenceEqual:判断两个序列是否相等。相等,返回true,否则返回false

元素操作符:
1. Single:返回序列中的唯一一条记录,如果没有或返回多条,则引发异常

2. SingleOrDefault:返回序列中的唯一一条记录,如果序列中不包含任何记录,则返回默认值,如果返回多条,则引发异常

3. First:取序列中满足条件的第一个元素,如果没有元素满足条件,则抛出异常

4. FirstOrDefault:取序列中满足条件的第一个元素,如果没有元素满足条件,则返回默认值(null)

5. ElementAt:返回序列中指定索引处的元素。如果索引超出范围会导致异常

6. ElementAtOrDefault:返回序列中指定索引处的元素;如果索引超出范围,则返回默认值

生成操作:

1. Empty:将返回一个指定类型的空集合,例:var str = Enumerable.Empty<string>();

2. DefaultIfEmpty:将空集合替换为具有默认值的单一实例集合。DefaultIfEmpty方法需要两个参数,第一个参数是一个泛型集合,第二个参数是相应类型的单个元素,如果第一个参数中不含有任何元素,它将返回第二个参数指定的单个元素

3. Range:用于生成指定范围内的整数的序列,例:var temp = Enumerable.Range(0, 10);

4. Repeat:用于生成包含一个重复值的集合,例:var temp = Enumerable.Repeat(0, 10);

原文地址:https://www.cnblogs.com/haosit/p/8142984.html

时间: 2024-10-10 04:09:13

Linq 常用查询操作符的相关文章

LINQ标准查询操作符(三)——Aggregate、Average、Distinct、Except、Intersect、Union、Empty、DefaultIfEmpty、Range、Repeat

本文来自:http://blog.csdn.net/xuejianwu/article/details/6931903 七.聚合操作符 聚合函数将在序列上执行特定的计算,并返回单个值,如计算给定序列平均值.最大值等.共有7种LINQ聚合查询操作符:Aggregate.Average.Count.LongCount.Max.Min和Sum. 1. Aggregate Aggregate操作符对集合值执行自定义聚合运算.例如,需要列出所有产品类别清单,每个类别名称之间用顿号连接.以下的代码演示了这一

Linq 标准查询操作符三

本文介绍了LINQ标准查询操作符.没有这些操作符,LINQ就不会存在.本文为理解这些操作符的功能提供了很好的基础.了解它们将会很有帮助,因为LINQ的各种Provider都是基于这些操作符来完成各自丰富的功能. 一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: using (NorthwindDataContext db = new NorthwindDataContext()) { //查

LINQ标准查询操作符详解(转)

 一. 关于LINQ       LINQ 英文全称是“Language-Integrated Query”,中文为“语言集成查询”,它是微软首席架构师.Delphi 之父和C# 之父——Anders Hejlsberg 提出的并由其团队着力打造的一组用于c#和Visual Basic语言的扩展,为 C# 和 Visual Basic 语言语法提供强大的查询功能.微软从2003年开始启动LINQ的开发,在VisualStudio2008中开始加入LINQ功能. LINQ提供的便利: 1)使用一种

LinQ—基本查询操作符 Select/Where语句

LinQ中的基本查询操作和SQL中的功能是一样的,对于其异同点,我们来了解了解: 1)Select 语法: <span style="font-family:SimHei;font-size:18px;"> public static IEnumerable<TResult> Select<TSource,TResult>( this IEnumerable<TSource>source,Func<TSource,TResult&g

Linq常用查询运算符

Linq一共包含五十几个查询运算符,常用的根据类型来区分一共有5类左右,这五类里面一些事在项目查询中经常用到的.不过linq运算符的命名十分规范,基本从字面意思就能猜测出来是干嘛用的,下面我们挑选一些常用的来介绍一下.根据分类我们能分成下面4种类型: 1.返回IEnumerable<T>类型的 1.1 Where:主要用于对于序列的筛选,跟在sql中对数据筛选用法是一样的 1 int[] array = { 1, 3, 5, 7, 2 }; 2 var query = array.Where(

LINQ标准查询操作符(二)——Join、GroupJoin、GroupBy、Concat、

本文来自:http://blog.csdn.net/xuejianwu/article/details/6931853 四.联接操作符 联接是指将一个数据源对象与另一个数据源对象进行关联或者联合的操作.这两个数据源对象通过一个共同的值或者属性进行关联. LINQ有两个联接操作符:Join和GroupJoin. 1. Join Join操作符类似于T-SQL中的inner join,它将两个数据源相联接,根据两个数据源中相等的值进行匹配.例如,可以将产品表与产品类别表相联接,得到产品名称和与其相对

LINQ标准查询操作符(一)——select、SelectMany、Where、OrderBy、OrderByDescending、ThenBy、ThenByDescending和Reverse

本文来自:http://blog.csdn.net/xuejianwu/article/details/6931804 一.投影操作符 1. Select Select操作符对单个序列或集合中的值进行投影.下面的示例中使用select从序列中返回Employee表的所有列: [csharp] view plaincopy using (NorthwindDataContext db=new NorthwindDataContext()) { //查询语法 var query = from e i

LINQ标准查询操作符(四)—AsEnumerable,Cast,OfType,ToArray,ToDictionary,ToList,ToLookup,First,Last,ElementAt

本文来自:http://blog.csdn.net/xuejianwu/article/details/6931926 十.转换操作符 转换操作符是用来实现将输入对象的类型转变为序列的功能.名称以“As”开头的转换方法可更改源集合的静态类型但不枚举(延迟加载)此源集合.名称以“To”开头的方法可枚举(即时加载)源集合并将项放入相应的集合类型. 1. AsEnumerable 所有实现了IEnumerable<T>接口的类型都可以调用此方法来获取一个IEnumerable<T>集合.

Linq的查询操作符

Linq有表达式语法和调用方法的语法.两者是可以结合使用,通常情况下也都是结合使用.表达式语法看上去比较清晰而调用方法的语法实现的功能更多,在此文章中介绍的是表达式语法.方法语法可以看System.Linq等命名空间下的扩展方法.Linq只能用于实现了IEnumerable或IEnumerable<T>接口的类,也就是可以用foreach的类都可以用linq. 注意在3.5和4.0版本上linq的关键字有些区别,下文是以4.0为准的. 1.投影操作符 select:对集合和序列中的值进行投影.