Группируйте по месяцам с критериями в Hibernate
Я пытаюсь получить отчет с использованием критериев и ProjectionList, и я довольно новый, используя это через спящий режим.
Поэтому у меня есть эта модель:
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<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();
}
В принципе, этот метод получает категорию и userId для фильтрации записей платежей и периода, который укажет, сколько месяцев отныне назад я хочу подвести итог. Как я могу получить результат суммы, сгруппированный по месяцам?
Любая помощь или подсказка Я по достоинству оценю это!
Ответы
Ответ 1
Я нашел ответ, и его довольно просто. Я изменил "groupProperty" в критериях ProjectionList для этого:
projectionList.add(Projections.sqlGroupProjection(
"month({alias}.DATE) as month, year({alias}.DATE) as year",
"month({alias}.DATE), year({alias}.DATE)",
new String[]{"month","year"},
new Type[] {Hibernate.DOUBLE}));
Хорошо. Я объясню sqlGroupProjection. Первый аргумент - это часть запроса после "select", например:
Select [firstPartOfSqlGroupProjection] * boo;
"{alias}" - это псевдоним, который спящий режим использует в запросе для ссылки на таблицу.
Второй аргумент функции sqlGroupProjection - это группа по критериям, третий аргумент - имена столбцов, которые вы получите из группы, и, наконец, тип данных, которые вы будете использовать.
Ответ 2
Вы можете использовать SQLQuery в спящем режиме, вот пример:
public List<MonthlyPoint> groupByMonth(ChartRequest request){
SQLQuery query = getSession().createSQLQuery("SELECT \n" +
"sum(this_.amount) as amount, \n" +
"extract(month from this_.fecha) as month, \n" +
"extract(year from this_.fecha) as year\n" +
"FROM jornada this_ \n" +
"GROUP BY \n" +
"month, \n" +
"year \n" +
"ORDER BY \n" +
"year asc, \n" +
"month asc");
query.setResultTransformer(Transformers.aliasToBean(MonthlyPoint.class));
return query.list();
}
public class MonthlyPoint {
private Double year;
private Double month;
private Double amount;
//-- getters and setters here --
}