如何通过两种不同类型的字段对 linq 查询结果进行排序 [重复]

Posted

技术标签:

【中文标题】如何通过两种不同类型的字段对 linq 查询结果进行排序 [重复]【英文标题】:How to order a linq query result by two different types fields [duplicate] 【发布时间】:2012-08-03 14:33:28 【问题描述】:

可能重复:Multiple “order by” in LINQ

我想知道如何通过两种不同类型的查询来排序,如下所示:

            var qry = (from m in dc.Orders
                   select new  m.OrderDate, m.OrderID ).OrderBy(o=>o.OrderDate+o.OrderID).ToList();
        bindingSource1.DataSource = qry;

OrdrerDate 是日期类型,OrderID 是 int 类型。

【问题讨论】:

msdn.microsoft.com/en-us/library/… 感谢您的链接。 【参考方案1】:

你正在寻找.ThenBy():

.OrderBy(o => o.OrderDate).ThenBy(o => o.OrderID).

【讨论】:

是的,就是这样。【参考方案2】:

我会说:

 var qry = (from m in dc.Orders
                   select new  m.OrderDate, m.OrderID ).OrderBy(o=>o.OrderDate).ThenBy(o.OrderID).ToList();

【讨论】:

【参考方案3】:

试试这个

var qry = (from m in dc.Orders 
               select new  m.OrderDate, m.OrderID ).OrderBy(o=>o.OrderDate).ThenBy(o.OrderID).ToList();

【讨论】:

【参考方案4】:

你可以使用 ThenBy 或者你可以编写这个 Linq 查询:

var qry = (from m in dc.Orders
            orderby m.OrderDate, m.OrderID
    select new m.OrderDate, m.OrderID).ToList

        bindingSource1.DataSource = qry;

【讨论】:

以上是关于如何通过两种不同类型的字段对 linq 查询结果进行排序 [重复]的主要内容,如果未能解决你的问题,请参考以下文章

如何将行号投影到 Linq 查询结果中

LINQ查询表达式 - LINQ 查询分组

c# linq groupby是默认去掉重复行吗

Linq标准查询操作符

对linq查询结果进行去重处理

使用 LINQ 和 XElement 查询 SQL 表