org.hibernate.criterion.Projections投影(Projections)

本文介绍了Hibernate中Projections类的使用,包括rowCount、avg、max等投影方法,以及如何设置别名和进行分组。通过示例展示了如何在查询中应用投影,避免显式使用group by子句,并利用Property.forName表达投影。

org.hibernate.criterion.Projections是 Projection 的实例工厂。我们通过调用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();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值