LINQ查询时有两种语法可供选择:查询表达式语法(Query Expression)和方法语法(Fluent Syntax)。 一、查询表达式语法 查询表达式语法是一种更接近SQL语法的查询方式。 LINQ查询表达式语法如下: 1 from<range variable> in <IEnumerable<T> or IQueryable<T> Collection> 2 <Standard Query Operators> <lambda expression> 3 <select or groupBy operator> <result formation> LINQ查询表达式
查询语法从一个From子句开始,然后是一个Range变量。 From子句的结构类似于“From rangeVariableName in IEnumerablecollection”。 在英语中,这意味着,从集合中的每个对象。 它类似于foreach循环:foreach(student in studentList)。 在From子句之后,您可以使用不同的标准查询运算符来过滤,分组,连接集合的元素。 LINQ中有大约50个标准查询运算符。标准查询运算符后面通常跟一个条件,这个条件通常使用lambda表达式来表示。 LINQ查询语法总是以Select或Group子句结束。 Select子句用于对数据进行整形。 您可以选择整个对象,因为它是或只有它的一些属性。 在上面的例子中,我们选择了每个结果字符串元素。 例如:我们要从数组中查询出偶数,查询表达式示例代码如下: var result = from p in ints where p % 2 == 0 select p; 查询表达式语法要点总结: 1、查询表达式语法与SQL(结构查询语言)语法相同。 2、查询语法必须以from子句开头,可以以Select或GroupBy子句结束 。 3、使用各种其他操作,如过滤,连接,分组,排序运算符以构造所需的结果。 4、隐式类型变量 - var可以用于保存LINQ查询的结果。 二、方法语法 方法语法(也称为流利语法)主要利用System.Linq.Enumerable类中定义的扩展方法和Lambda表达式方式进行查询,类似于如何调用任何类的扩展方法。 以下是一个示例LINQ方法语法的查询,返回数组中的偶数: var result = ints.Where(p => p % 2 == 0).ToArray(); 从上面的示例代码中可以看出:方法语法包括扩展方法和Lambda表达式。 扩展方法Where()在Enumerable类中定义。 如果你检查Where扩展方法的签名,你会发现Where方法接受一个谓词委托,如Func <Student,bool>。 这意味着您可以传递任何接受Student对象作为输入参数的委托函数,并返回一个布尔值,如下图所示。 lambda表达式作为在Where子句中传递的委托传递。 在下一节中学习lambda表达式。
三、查询表达式语法VS方法语法 查询表达式语法与方法语法存在着紧密的关系
|
|