更优雅的方式来编写一个hibernate查询

时间:2011-05-07 00:52:44

标签: java hibernate

有人可以帮我写一个更好的代码吗?我尝试了这个,但它不起作用:

Query query = session.createQuery("from MyTable order by :sortvariable :sortorder");
query.setParameter("sortvariable", sortvar);
query.setParameter("sortorder", order);

这个效果不佳

Query query = session.createQuery("from MyTable table order by table." + sortvar + " " + " :sortorder");
query.setParameter("sortorder", order);

我设法让它解决这个问题:

Query query = session.createQuery("from MyTable table order by table." + sortvar + " " + order);

我需要使用查询来执行此操作,因为我正在使用setMaxResults()和setFirstResult()。

1 个答案:

答案 0 :(得分:0)

我认为您不能使用参数来识别关键字。是否可以使用条件API执行您要执行的操作?

boolean sortAscending = ...;
Criteria criteria = session.createCriteria(MyTable.class);
criteria.addOrder(sortAscending? Order.asc(sortVar): Order.desc(sortVar));