簡體   English   中英

編寫休眠查詢的更優雅的方法

[英]More elegant way to write a hibernate query

有人可以幫我寫一個更好的代碼。 我嘗試了這個,但是沒有用:

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()。

我認為您不能使用參數那樣來標識關鍵字。 是否可以使用條件API來完成您想做的事情?

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

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM