Группировать по месяцам с критериями в Hibernate - PullRequest
28 голосов
/ 14 января 2010

Я пытаюсь получить отчет, используя 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<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();

 }

В основном этот метод получает Category и userId для фильтрации записей платежей и периода,кто укажет, сколько месяцев с этого момента я хочу подвести.Как я могу получить итоговый результат, сгруппированный по месяцам?

Любая помощь или совет, я буду признателен за это!

Ответы [ 2 ]

39 голосов
/ 15 января 2010

Я нашел ответ, и это довольно просто.Я изменил «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 - это группа по критериям, третий аргумент - имена столбцов, по которым вы получите группу, и, наконец, тип данных, которые вы будете использовать.

0 голосов
/ 30 мая 2016

Вы можете использовать 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 --
}
...