使用 Hibernate 中的条件按月分组

Posted

技术标签:

【中文标题】使用 Hibernate 中的条件按月分组【英文标题】:Group by month with criteria in Hibernate 【发布时间】:2011-01-05 06:12:39 【问题描述】:

我正在尝试使用 Criteria 和 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();

 

基本上,此方法接收一个类别和一个用户 ID 来过滤付款记录和一个期间,谁将表明我想从现在到后面多少个月求和。如何获得按月分组的总和结果?

任何帮助或提示,我将不胜感激!

【问题讨论】:

【参考方案1】:

你可以在hibernate中使用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 --

【讨论】:

【参考方案2】:

我找到了答案,而且非常简单。我为此更改了 ProjectionList 标准中的“groupProperty”:

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 函数的第二个参数是 group by 条件,第三个参数是您将从 group by 获得的列名,最后是您将使用的数据类型。

【讨论】:

如何处理不同的数据库?比如 MSSQL 和 Oracle?如 Oracle 使用 to_char 和 mssql 使用 weeknum... 我在获取结果集中的年份时遇到问题。即使查询正确,结果集也没有年份值。通过使用帖子 ***.com/questions/39444196/… 中的最后一个答案修复

以上是关于使用 Hibernate 中的条件按月分组的主要内容,如果未能解决你的问题,请参考以下文章

MySQL之按月拆分主表并按月分表写入数据提高数据查询速度

mysql 如何按月分组查询出当前年度每个月的短信数量(数据库中这个月要是为空的话就用0条怎么显示出来)

mycat:水平分库之按月分库

我想计算 nodejs mongodb 列中的三个字段,需要按月分组

如何按月对数组中的值进行分组?

如何使用sql从日期字段按月分组