问题
How to use order by clause for sort by sum of field
Entity:
class MyClass {
private int a;
private int b;
//...
}
HQL works correctly:
"SELECT myclass FROM MyClass myclass ORDER BY myclass.a + myclass.b DESC "
How to do the same thing using Criteria API?
回答1:
As you said you could use @Formula
@Column(name="column_a")
private Integer a;
@Column(name="column_b")
private Integer b;
@Formula("(column_a+column_b)")
private Integer c;
After that you can sort by property c
like
criteria.addOrder(Order.asc("c"));
来源:https://stackoverflow.com/questions/19742072/hibernate-how-to-use-order-by-clause-for-sort-by-sum-of-field