我试图得到一个报告使用Criteria和ProjectionList,我很新的使用这通过hibernate。
所以我有这个模型:
private Long _userId;
private Category _category;
private Long _companyId;
private Double _amount;
private Date _date;
和我建立查询使用这:
public List sumPaymentsByUserCategoryPeriod(Category category, Long userId,Integer period){
GregorianCalendar from = new GregorianCalendar();
from.add(Calendar.MONTH, -period);
List resultDTO= new ArrayList();
Criteria criteria = getSession().createCriteria(Payment.class);
criteria.add(Restrictions.eq("_category", category));
criteria.add(Restrictions.eq("_userId",userId));
criteria.add(Restrictions.between("_date", from.getTime(), new Date()));
ProjectionList projectionList = Projections.projectionList();
projectionList.add(Projections.sum("_amount"));
projectionList.add(Projections.groupProperty("_date"));
criteria.setProjection(projectionList);
return criteria.list();
}
基本上,这个方法接收一个类别和一个userId来过滤支付记录,一个期间,谁将指示从现在到几个月我想要总和。如何获得按月分组的总结果?
任何帮助或提示,我会欣赏它!