有沒有一種方法可以在HQL中創建一個Distinct查詢。通過使用“ distinct”關鍵字或其他某種方法。我不確定distinct是否是HQL的有效鍵,但是我正在尋找與SQL關鍵字“ distinct”等效的HQL。
3 回答

慕村225694
TA貢獻1880條經驗 獲得超4個贊
值得注意的是,distinctHQL中的關鍵字不會直接映射到distinctSQL中的關鍵字。
如果distinct在HQL中使用關鍵字,則有時Hibernate將使用distinctSQL關鍵字,但是在某些情況下,它將使用結果轉換器產生不同的結果。例如,當您使用這樣的外部聯接時:
select distinct o from Order o left join fetch o.lineItems
在這種情況下,不可能在SQL級別上過濾掉重復項,因此Hibernate 在執行SQL查詢之后使用a ResultTransformer來過濾重復項。

慕娘9325324
TA貢獻1783條經驗 獲得超4個贊
下次做這樣的事情
Criteria crit = (Criteria) session.
createCriteria(SomeClass.class).
setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);
List claz = crit.list();
添加回答
舉報
0/150
提交
取消