Hibernate使用Projections进行聚合操作

王朝学院·作者佚名  2009-12-31
窄屏简体版  字體: |||超大  

通过Hibernate进行字段中的数据计算,在JDBC中,就使用SQL的sum等方法,而在使用Hibernate中,需要使用Projections的对象.

首先介绍一下Projections:

org.hibernate.criterion.Projections是 Projection 的实例工厂,我们通过调用setProjection()应用Projections对象进行一个查询.

下面开始操作:

同样需要创建Criteria对象,这对象非常重要,几乎完成了Hibernate中大多的查询功能,配合HQL使用,相应厉害.

Java代码

Criteria criteria = session.createCriteria(AccCasherDaySupply.class);

Criteria criteria = session.createCriteria(AccCasherDaySupply.class);

通过Session创建Criteria对象,参数为你要查询的对象类名(这里注意区分大小写).

通过Criteria对象可以使用setProjection的方法,该方法将进行一个Projections的查询.

Java代码

criteria.setProjection(****);

criteria.setProjection(****);

接下来就是进行真正的聚合操作部分了,使用Projections对象插入到****的参数中.

Projects对象具有大多聚合的方法,基本上有:rowCount(),avg(),max(),groupProperty(),alias(),property(),sum()...

以sum()为例,如果需要计算某个字段数据的合,将使用sum()方法:

Java代码

criteria.setProjection(Projections.sum("字段名"));

criteria.setProjection(Projections.sum("字段名"));

通过以上代码,criteria将得到相应字段名的合.

最后通过criteria.list()得到Projections查询的最终结果.

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lyr1985/archive/2009/12/30/5105409.aspx

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航