C# Linq 查询语法与方法语法

简介:

        通过使用 C# 3.0 中引入的声明性查询语法,介绍性 LINQ 文档中的多数查询都被编写为查询表达式。 但是,.NET 公共语言运行时 (CLR) 本身并不具有查询语法的概念。 因此,在编译时,查询表达式会转换为 CLR 的内容:方法调用。 这些方法称为“标准查询运算符”,它们具有如下名称: Where、 Select、 GroupBy、 Join、 Max、 Average 等。可以通过使用方法语法而非查询语法来直接调用这些方法。

         通常我们建议使用查询语法,因为它通常更简单、更易读;但是方法语法和查询语法之间并无语义上的区别。 此外,一些查询(如检索匹配指定条件的元素数的那些查询或检索具有源序列中的最大值的元素的查询)只能表示为方法调用。 System.Linq 命名空间中的标准查询运算符的参考文档通常使用方法语法。 因此,即使在开始编写 LINQ 查询时,熟悉如何在查询和查询表达式本身中使用方法语法也非常有用。

       简单的理解即是,Linq的查询语法一般都有对应的方法语法。

标准查询运算符

 

使用

  1. Linq 查询语法与方法语法使用比较。
  2. 条件表达式 (num % 2 == 0) 是作为内联参数传递到 Where 方法的:Where(num => num % 2 == 0).。此内联表达式称为 lambda 表达式。 将代码编写为匿名方法或泛型委托或表达式树是一种便捷的方法。
查询方法
from num in numbersnumbers
where num % 2 == 0Where(num => num % 2 == 0)
orderby numOrderBy(n => n)

 

class QueryVMethodSyntax
{
    static void Main()
    {
        int[] numbers = { 5, 10, 8, 3, 6, 12};

        //查询语法:
        IEnumerable<int> numQuery1 = 
            from num in numbers
            where num % 2 == 0
            orderby num
            select num;

        //方法语法:
        IEnumerable<int> numQuery2 = numbers.Where(num => num % 2 == 0).OrderBy(n => n);

        foreach (int i in numQuery1)
        {
            Console.Write(i + " ");
        }
        /*输出:6 8 10 12*/
        Console.WriteLine(System.Environment.NewLine);

        foreach (int i in numQuery2)
        {
            Console.Write(i + " ");
        }
        /*输出:6 8 10 12*/
        Console.ReadKey();
    }
}

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#中,LINQ(Language Integrated Query)是一种用于查询和操作各种数据源的语言集成查询技术。LINQ提供了一种统一的查询语法,可以用于查询对象集合、数据库、XML文档等各种数据源。 在给出的引用中,引用\[1\]展示了如何使用LINQ进行查询结果排序。在示例中,通过使用`orderby`关键字,可以按照指定的字段进行排序。例如,`orderby e.LevelNum, e.Name, e.Age descending`表示按照级别、姓名和年龄进行排序,其中`descending`表示降序排序。 引用\[2\]展示了如何使用LINQ进行联合查询。通过使用`from`关键字和`select`关键字,可以将两个集合进行联合查询,并输出结果。例如,`from e in empArray from l in empLeArray select new { e, l }`表示将`empArray`和`empLeArray`两个集合进行联合查询,并输出结果。 引用\[3\]展示了LINQ支持的查询环境之一,即对象集合。在示例中,通过创建`List<string>`、`Dictionary<string, string>`、`ArrayList`和`Hashtable`等对象集合,可以在LINQ中进行查询操作。 综上所述,C#中的LINQ查询可以通过使用`orderby`关键字进行结果排序,使用`from`和`select`关键字进行联合查询,并支持在对象集合中进行查询操作。 #### 引用[.reference_title] - *1* *2* *3* [C#Linq查询表达式](https://blog.csdn.net/weixin_49251429/article/details/123671040)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值