15.7. 投影(Projections)、聚合(aggregation)和分组(grouping)

org.hibernate.criterion.ProjectionsProjection 的实例工厂。我们通过调用 setProjection()应用投影到一个查询。

  1. List results = session.createCriteria(Cat.class)
  2. .setProjection( Projections.rowCount() )
  3. .add( Restrictions.eq("color", Color.BLACK) )
  4. .list();
  1. List results = session.createCriteria(Cat.class)
  2. .setProjection( Projections.projectionList()
  3. .add( Projections.rowCount() )
  4. .add( Projections.avg("weight") )
  5. .add( Projections.max("weight") )
  6. .add( Projections.groupProperty("color") )
  7. )
  8. .list();

在一个条件查询中没有必要显式的使用 "group by" 。某些投影类型就是被定义为 分组投影,他们也出现在SQL的group by子句中。

你可以选择把一个别名指派给一个投影,这样可以使投影值被约束或排序所引用。下面是两种不同的实现方式:

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

alias()as()方法简便的将一个投影实例包装到另外一个 别名的Projection实例中。简而言之,当你添加一个投影到一个投影列表中时 你可以为它指定一个别名:

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

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

  1. List results = session.createCriteria(Cat.class)
  2. .setProjection( Property.forName("name") )
  3. .add( Property.forName("color").eq(Color.BLACK) )
  4. .list();
  1. List results = session.createCriteria(Cat.class)
  2. .setProjection( Projections.projectionList()
  3. .add( Projections.rowCount().as("catCountByColor") )
  4. .add( Property.forName("weight").avg().as("avgWeight") )
  5. .add( Property.forName("weight").max().as("maxWeight") )
  6. .add( Property.forName("color").group().as("color" )
  7. )
  8. .addOrder( Order.desc("catCountByColor") )
  9. .addOrder( Order.desc("avgWeight") )
  10. .list();