void

          Hibernate-投影

          org.hibernate.criterion.ProjectionsProjection 的實例工廠。我們通過調用 setProjection()應用投影到一個查詢。

          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.rowCount() )
          .add( Restrictions.eq("color", Color.BLACK) )
          .list();
          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.projectionList()
          .add( Projections.rowCount() )
          .add( Projections.avg("weight") )
          .add( Projections.max("weight") )
          .add( Projections.groupProperty("color") )
          )
          .list();

          在一個條件查詢中沒有必要顯式的使用 "group by" 。某些投影類型就是被定義為 分組投影,他們也出現在SQL的group by子句中。

          你可以選擇把一個別名指派給一個投影,這樣可以使投影值被約束或排序所引用。下面是兩種不同的實現方式:

          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.alias( Projections.groupProperty("color"), "colr" ) )
          .addOrder( Order.asc("colr") )
          .list();
          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.groupProperty("color").as("colr") )
          .addOrder( Order.asc("colr") )
          .list();

          alias()as()方法簡便的將一個投影實例包裝到另外一個 別名的Projection實例中。簡而言之,當你添加一個投影到一個投影列表中時 你可以為它指定一個別名:

          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.projectionList()
          .add( Projections.rowCount(), "catCountByColor" )
          .add( Projections.avg("weight"), "avgWeight" )
          .add( Projections.max("weight"), "maxWeight" )
          .add( Projections.groupProperty("color"), "color" )
          )
          .addOrder( Order.desc("catCountByColor") )
          .addOrder( Order.desc("avgWeight") )
          .list();
          List results = session.createCriteria(Domestic.class, "cat")
          .createAlias("kittens", "kit")
          .setProjection( Projections.projectionList()
          .add( Projections.property("cat.name"), "catName" )
          .add( Projections.property("kit.name"), "kitName" )
          )
          .addOrder( Order.asc("catName") )
          .addOrder( Order.asc("kitName") )
          .list();

          你也可以使用Property.forName()來表示投影:

          List results = session.createCriteria(Cat.class)
          .setProjection( Property.forName("name") )
          .add( Property.forName("color").eq(Color.BLACK) )
          .list();
          List results = session.createCriteria(Cat.class)
          .setProjection( Projections.projectionList()
          .add( Projections.rowCount().as("catCountByColor") )
          .add( Property.forName("weight").avg().as("avgWeight") )
          .add( Property.forName("weight").max().as("maxWeight") )
          .add( Property.forName("color").group().as("color" )
          )
          .addOrder( Order.desc("catCountByColor") )
          .addOrder( Order.desc("avgWeight") )
          .list();

          posted on 2008-07-19 12:16 void 閱讀(488) 評論(0)  編輯  收藏 所屬分類: Hibernate

          主站蜘蛛池模板: 元氏县| 灵璧县| 云霄县| 青田县| 卢龙县| 乐亭县| 揭西县| 株洲市| 苏尼特右旗| 阳江市| 台南市| 新密市| 石泉县| 措勤县| 巴彦淖尔市| 中江县| 安阳县| 蒙城县| 寿光市| 扎赉特旗| 东宁县| 搜索| 黔江区| 三门县| 保德县| 汕头市| 红原县| 蛟河市| 荃湾区| 汤原县| 红河县| 襄垣县| 芒康县| 淳安县| 彭山县| 岗巴县| 施甸县| 子洲县| 个旧市| 盐亭县| 名山县|