.NET LINQ 投影运算

 

  • 投影运算

     投影是指将对象转换为一种新形式的操作,该形式通常只包含那些将随后使用的属性。 通过使用投影,您可以构建依据每个对象生成的新类型。 您可以映射属性,并对该属性执行数学函数。 还可以在不更改原始对象的情况下映射该对象。

  • 方法

方法名

说明

C# 查询表达式语法

Visual Basic 查询表达式语法

更多信息

Select

映射基于转换函数的值。

select

Select

Enumerable.Select

Queryable.Select

SelectMany

映射基于转换函数的值序列,然后将它们展平为一个序列。

使用多个 from 子句

使用多个 From 子句

Enumerable.SelectMany

Queryable.SelectMany

  • Select 与 SelectMany

     Select() 和 SelectMany() 的工作都是依据源值生成一个或多个结果值。 Select() 为每个源值生成一个结果值。因此,总体结果是一个与源集合具有相同元素数目的集合。与之相反,SelectMany() 将生成单一总体结果,其中包含来自每个源值的串联子集合。作为参数传递到 SelectMany() 的转换函数必须为每个源值返回一个可枚举值序列。然后,SelectMany() 将串联这些可枚举序列以创建一个大的序列。
     下面两个插图演示了这两个方法的操作之间的概念性区别。在每种情况下,假定选择器(转换)函数从每个源值中选择一个由花卉数据组成的数组。
     下图描述 Select() 如何返回一个与源集合具有相同元素数目的集合。
 
     下图描述 SelectMany() 如何将中间数组序列串联为一个最终结果值,其中包含每个中间数组中的每个值。
 

  • 代码示例

class Bouquet
{
    public List<string> Flowers { get; set; }
}
static void SelectVsSelectMany()
{
    List<Bouquet> bouquets = new List<Bouquet>() {
        new Bouquet { Flowers = new List<string> { "sunflower", "daisy", "daffodil", "larkspur" }},
        new Bouquet{ Flowers = new List<string> { "tulip", "rose", "orchid" }},
        new Bouquet{ Flowers = new List<string> { "gladiolis", "lily", "snapdragon", "aster", "protea" }},
        new Bouquet{ Flowers = new List<string> { "larkspur", "lilac", "iris", "dahlia" }}
    };
    IEnumerable<List<string>> query1 = bouquets.Select(bq => bq.Flowers);
    IEnumerable<string> query2 = bouquets.SelectMany(bq => bq.Flowers);
    Console.WriteLine("Results by using Select():");
    foreach (IEnumerable<String> collection in query1)
        foreach (string item in collection)
            Console.WriteLine(item);
    Console.WriteLine("\nResults by using SelectMany():");
    foreach (string item in query2)
        Console.WriteLine(item);
}
使用.NET中的LINQ进行动态排序可以通过使用Dynamic LINQ库来实现。Dynamic LINQ库是由Microsoft提供的一个扩展库,允许我们在运行时构建和执行动态LINQ查询。 首先,我们需要在项目中添加Dynamic LINQ库的引用,这可以通过从NuGet包管理器中安装Dynamic LINQ包来完成。 在代码中,我们可以使用OrderBy和ThenBy方法来进行动态排序。这两个方法可以接收一个字符串参数作为排序表达式。这个表达式可以是字段名称、属性名称或任何适用的表达式。 例如,假设我们有一个存储学生信息的列表,并且我们希望根据学生的年龄进行排序: ```csharp using System.Linq; using System.Linq.Dynamic; class Program { static void Main(string[] args) { List<Student> students = new List<Student>() { new Student() { Name = "Tom", Age = 20 }, new Student() { Name = "Jerry", Age = 18 }, new Student() { Name = "Alice", Age = 22 } }; Console.WriteLine("按年龄升序排序:"); var sortedStudents = students.OrderBy("Age"); foreach (var student in sortedStudents) { Console.WriteLine(student.Name); } Console.WriteLine("按年龄降序排序:"); sortedStudents = students.OrderByDescending("Age"); foreach (var student in sortedStudents) { Console.WriteLine(student.Name); } Console.ReadLine(); } } class Student { public string Name { get; set; } public int Age { get; set; } } ``` 上述代码中,我们通过字符串参数"Age"来对学生列表进行排序。OrderBy方法将按照升序对学生列表进行排序,而OrderByDescending方法将按照降序进行排序。 通过以上代码,我们可以根据需要动态指定排序的字段,并根据要求进行升序或降序排序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值