J'essaie d'obtenir un rapport en utilisant Criteria et ProjectionList, et je suis assez nouveau en utilisant hibernate. J'ai donc ce modèle:Regrouper par mois avec des critères dans Hibernate
private Long _userId;
private Category _category;
private Long _companyId;
private Double _amount;
private Date _date;
Et je crée la requête en utilisant ceci:
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();
}
Fondamentalement, cette méthode receive une catégorie et un userId pour filtrer les enregistrements des paiements et une période, qui indiquera combien de mois à partir de maintenant à l'arrière, je veux résumer. Comment puis-je regrouper les résultats de la somme par mois?
Une aide ou un conseil j'apprécierais!
Comment gérer différents DB? tels que MSSQL et Oracle? comme Oracle utilise to_char et mssql utilisent weeknum ... – zolibra