繁体   English   中英

在nhibernate中排序整数或十进制列

[英]sorting integer or decimal column in nhibernate

我正在尝试对十进制或整数列进行排序。 但是在排序升序为零时排在最后。

代码是:

criteria.AddOrder(Order.Asc(Projections.Cast(NHibernateUtil.Decimal,  Projections.Property("cloumn1")))));

输出:

35342860
36870852
87654321
213123213
0
0

代码有问题吗? 或什么是解决方案?

这些很可能是空值。 您可以查看使用条件限制,或将其设置为默认值0的不可为空的列,这似乎正是您所追求的。

有条件的限制就是这样

.AddOrder
    (
        Order.Asc
        (
            Projections.Conditional
            (
                Restrictions.IsNull("cloumn1"),
                Projections.Constant(1),
                Projections.Constant(0)
            )
        )
    )

如果您按第一顺序输入,则会将null放在顶部并显示为0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM