ruby-on-rails – 按月分组计算

我有一个Albums表,其中有一个名为release_date的日期列.

我想获得所有月份组合的列表以及该月/年中发布的专辑数量.

所以,输出可能是这样的:

> 2016年11月 – 11
> 2016年10月 – 4
> 2016年7月 – 19日
> 2015年12月 – 2

Postgres 9.6上的Ruby 2.3.1 w / Rails 5,FWIW.

解决方法

我假设你的表是单一的Album per Rails惯例.如果没有,请考虑更改它.

Album.all.map { |album| [Date::MONTHNAMES[album.date.month],album.date.year].join(' ') }
  .each_with_object(Hash.new(0)) { |month_year,counts| counts[month_year] += 1 }

说明:

.map方法遍历相册并返回由[“month year”,“month year”,…]组成的字符串数组.

.each_with_object方法是一种标准计数算法,它返回一个带有每个唯一数组项的计数的哈希.

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...