七郎's JavaBlog

          草木竹石皆可為劒。至人之用人若鏡,不將不迎,應而不藏,故能勝物而不傷。
          posts - 60, comments - 14, trackbacks - 0, articles - 0

          Hibernate提供了HQL,方便查詢的編寫。但是在某些情況下,我更喜歡用Criteria,因為它的語義非常明確。

          在處理對象關聯的時候,經常要對對象下的某個集合字段進行條件限制。比如下面的類:

          public class MainClass{  protected long id;  protected int type;  protected Set<SubClass> subs= new HashSet<SubClass>();  ......  getter/setter}  public class SubClass{  protected long id;  protected int value;  protected Set<MainClass> ms = new HashSet<MainClass>();  ...... getter/setter} 

          在初始化數據中,假設MainClass的實例m1含有SubClass的實例s1,s2,s3;MainClass的實例m2含有SubClass的實例s2,s3,s4。

          而其中s1,s2,s3,s4的value分別是1,2,3,4 

          現在要查詢出 MainClass中SubClass集合含有SubClass實例value為2的的MainClass實例并且type為1,可以使用下面的查詢方法:

            DetachedCriteria criteria = DetachedCriteria        .forClass(MainClass.class);  criteria.add(        Restrictions.eq("type", new Integer(1)))        .createAlias("subs", "s").add(             Restrictions.eq("s.value", new Integer(2)));

          執行此查詢對象后會得到符合條件的MainClass實例。

          需要注意的是在獲取的MainClass實例中,subs是完全的記錄集,而不是經過過濾的記錄集,也就是相當于根據MainClass的ID獲取的完整實例一樣。

          ps: 

            如果需要過濾subs的記錄集,需要使用額外的過濾方法,請參考Hibernate的具體實現。

            使用HQL也可以很方便地實現,但是需要給出完整的join標記,不如createAlias來得方面和直觀。 


          只有注冊用戶登錄后才能發表評論。


          網站導航:
           
          主站蜘蛛池模板: 新民市| 札达县| 江津市| 麟游县| 永善县| 扶绥县| 乾安县| 开江县| 盘山县| 上蔡县| 永胜县| 手机| 汉沽区| 涟源市| 蕲春县| 喜德县| 红安县| 遂溪县| 勃利县| 巢湖市| 西宁市| 海南省| 东兰县| 横峰县| 昌黎县| 团风县| 乌什县| 平度市| 军事| 安义县| 宜川县| 大石桥市| 靖边县| 安达市| 武陟县| 北流市| 都兰县| 酉阳| 墨江| 长海县| 方山县|