按月计算,按年计算
我有一个Albums
表,其中有一个名为release_date
的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
方法是一种标准计数算法,它返回一个带有每个唯一数组项的计数的哈希。
数据库层是此任务所属的位置,而不是Ruby:
Album.group("TO_CHAR(release_date, 'Month YYYY')").count
为何使用数据库层? 仅仅因为它与其他任何东西相比都是闪电般快速的,与Ruby相比它具有资源效率,它可以完美地扩展,并且由于拥有大量的Album
记录,您可以简单地重载内存并且从不实际完成处理。