簡體   English   中英

如何使用“多對多”關系標准?

[英]How to use criterias for “many-to-many” relation?

下午好。 學習Hibernate,有必要使用該標准編寫以下查詢。 有兩個實體-水果店和通訊類型-多對多。 因此,我們實際上有三個表(以及Java的相應類):Fruit(ID,名稱),Shop(ID,名稱)和ShopFruit(shop_id,fruit_id)。 那么,與獲取例如橘子的商店清單的標准一樣? 提前致謝。

我認為您可以使用這樣的別名:

List questions = session.createCriteria(Shop.class)
  .createAlias("Fruits", "f")
  .add(Restrictions.eq("f.name", "tangerine"))
  .list();

另請參閱此問題 但是,我認為您也可以在Hibernate映射中為Fruit設置一個集合來解決此問題:

<set name="stores" table="ShopFruit" cascade="all">
  <key column="fruit_id" />
  <many-to-many column="store_id" />
</set>

通過商店集擴展您的Fruit類:

class Fruit {
  ...
  Set<Store> stores;
  ...
}

如果您要從數據庫中加載“橘子” Fruit對象,則stores變量應包含所有出售它的商店。

暫無
暫無

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

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