首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linq to NHibernate多个OrderBy调用

您好!您提到的 Linq to NHibernate 是一个用于将 LINQ 查询表达式转换为 NHibernate 查询的库。关于多个 OrderBy 调用,您可以使用 ThenBy 或 ThenByDescending 方法来实现。

在 LINQ 查询中,您可以使用 ThenBy 或 ThenByDescending 方法来指定多个排序条件。例如:

代码语言:csharp
复制
var query = from item in session.Query<Item>()
            orderby item.Category, item.Price descending
            select item;

这个查询将首先按照 Category 属性进行排序,然后在同一类别中按照 Price 属性进行降序排序。

如果您使用的是 QueryOver 查询,则可以使用 ThenOrderBy 或 ThenOrderByDescending 方法来实现多个排序条件。例如:

代码语言:csharp
复制
var query = session.QueryOver<Item>()
                   .OrderBy(x => x.Category).Asc
                   .ThenOrderBy(x => x.Price).Desc;

这个查询将首先按照 Category 属性进行排序,然后在同一类别中按照 Price 属性进行降序排序。

希望这个答案能够帮助您解决问题!

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • LINQ在开发中的地位?

    LINQ是微软将在C# 3.0中将推出的语言集成查询技术,许多人也将LINQ叫做微软的ORM。LINQ不仅仅针对关系数据库,它只是解决一个问题Data!...在Linq之前在.net领域最流行的框架就是Nhibernate。是不是在LINQ之后Nhibernate就要消失呢?答案自然是否定的。...这里有个帖子Microsoft LINQ + NHibernate: 在那篇帖子中,作者列举了三大原因: 在DLINQ中,虽然可以在语言层级定义查询逻辑。...而LINQ + NHibernate的好处则是: 类型安全的查询,并且能使用智能提示功能!这样可以不用学习HQL了。 能获得所有NHibernate所拥有的能力。...这个项目也包含着上面所说的NHibernate.Linq. Implementing Linq for NHibernate: A How To Guide - Part 1

    1.4K60

    在VS中调试LINQ(Lambda)

    OrderBy()的返回值是IOrderedEnumerable,所以运行了OrderBy()后,单个对象的迭代就会结束,继续下一个对象的迭代。...,然后把这个暂存结果集执行OrderBy()后面的Linq方法。...在 4 的基础上,对于IEnumerable,如果有多个条件,我们可以写在同一个Where()里,也可以拆开写在多个Where()里,不会影响效率的,因为不会生成多个暂存结果集。.../ 如何在C#中调试LINQ查询:https://michaelscodingspot.com/debug-linq-in-csharp/ 扩展 如何知道每一步链式调用的结果 如何知道每一步链式调用的结果...图示 下图是不填条件偷懒法:每个Linq语句的结果让下一个Linq语句输出,下一个Linq语句不要设置条件,只设置操作。所以图中是 OrderBy输出Where的执行结果。

    4.7K30

    LinQ 查询表达式

    操作方式使用了 LINQ,之前一直对 LINQ 的查询语法不太喜欢,这次使用之后,感觉比方法语法更容易接受,因此详细总结一下查询表达式的语法。 数据查询历来都表示为简单的字符串,没有编译时类型检查。...借助 LINQ,查询成为了最高级的语言构造,就像类、方法和事件一样。 LINQ 最明显的”语言集成”部分就是查询表达式。...在第一个 from 子句与最后一个 select 或 group 子句之间,可以包含以下这些可选子句中的一个或多个: where、orderby、join、let 甚至是其他 from 子句。...where 子句 使用 where 子句可基于一个或多个谓词表达式,从源数据中筛选出元素。...let 子句 使用 let 子句可将表达式(如方法调用)的结果存储在新范围变量中。

    1.8K20

    Linq基础知识小记三

    Kobe", "Curry", "Durrent" }; IEnumerable result = names.OrderBy(n => n.Split().Last()); n.Split...2、本地查询和解释查询 本地查询(Linq To Object)和解释查询(Linq To Sql)对于子查询的处理方式不一样. (1)、本地查询(Linq To Object)对于外部查询的每一次循环...延迟执行的特性,因为子查询总是间接调用的. 2、Linq查询创建攻略 常用的Linq查询方式有三种两种已经在前面用到过了,下面有个案例,去除一个字符串数组中的所有的元音字母,然后对长度大于1的元素进行按长度排序...3、数据转换 Linq的数据转换,也叫结果投影。...而且,我们可以使用多个let关键字,并且后面的 let表达式可以引用前一个let关键字引入的变量。

    93180

    连贯NHibernate 1.0正式发布

    连贯NHibernate(Fluent NHibernate) 是通过编程方式而不是使用XML配置文件创建NHibernate映射的API。...它的目标是在项目中运用NHibernate时减少所遇到的困难,提供更好的可读性、可测试性和编译时的安全性。...连贯NHibernate降低了复杂性,并进一步加强了约定胜于配置的原则,即任何一个映射的最常用设置是默认的。 除了编译时的检查外连贯NHibernate还为你的映射的测试提供了一个健壮的API。...Wiki上有教程告诉怎么用,园子里的inday的几篇文章可以先看一下: [原创]Fluent NHibernate之旅 [原创]Fluent NHibernate之旅二--Entity Mapping...[原创]Fluent NHibernate之旅(三)—继承 codeproject上也有一篇针对RC的文章:Fluent NHibernate and Linq2NHibernate – Demo Project

    64670

    【深入浅出C#】章节 9: C#高级主题:LINQ查询和表达式

    它更加紧凑,可以在方法链中连续调用多个操作。以下是一些常见的LINQ方法: Where: 用于过滤数据。 OrderBy / OrderByDescending: 用于排序数据。...操作更加灵活,可以根据需求组合不同的方法调用。 支持的操作更丰富,因为可以调用LINQ扩展方法。 适用于需要更大程度的代码控制和性能优化的情况。...四、LINQ查询操作和结果 4.1 如何构建和组合多个LINQ查询操作符 构建和组合多个LINQ查询操作符是通过链式调用操作符的方式来实现的。...你可以在一个LINQ查询中使用多个操作符,以便对数据进行复杂的查询、过滤、投影和操作。...以下是如何构建和组合多个LINQ查询操作符的示例: 假设我们有一个包含一些人员信息的集合,每个人员都有姓名、年龄和职业属性。

    2.1K61
    领券