亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在HQL中創建不同的查詢

如何在HQL中創建不同的查詢

有沒有一種方法可以在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來過濾重復項。


查看完整回答
反對 回復 2019-12-27
?
慕娘9325324

TA貢獻1783條經驗 獲得超4個贊

下次做這樣的事情


 Criteria crit = (Criteria) session.

                  createCriteria(SomeClass.class).

                  setResultTransformer(Criteria.DISTINCT_ROOT_ENTITY);


 List claz = crit.list();


查看完整回答
反對 回復 2019-12-27
  • 3 回答
  • 0 關注
  • 871 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號