Sto cercando di ottenere un rapporto utilizzando Criteria e ProjectionList, e sono piuttosto nuovo che usa questo attraverso l'ibernazione. Così ho questo modello:Raggruppa per mese con i criteri in Hibernate
private Long _userId;
private Category _category;
private Long _companyId;
private Double _amount;
private Date _date;
E costruire la query utilizzando questo:
public List sumPaymentsByUserCategoryPeriod(Category category, Long userId,Integer period){
GregorianCalendar from = new GregorianCalendar();
from.add(Calendar.MONTH, -period);
List<CategoryAmount> resultDTO= new ArrayList<CategoryAmount>();
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();
}
Fondamentalmente questo metodo ricevono una categoria e un ID utente per filtrare i pagamenti record e un periodo, che indicherà quanti mesi da ora in poi voglio riassumere. Come posso ottenere il risultato somma raggruppato per mesi?
Qualsiasi aiuto o suggerimento lo apprezzerò!
Come gestire diversi database? come MSSQL e Oracle? come Oracle usa to_char e mssql usa weeknum ... – zolibra