按月计算,按年计算

时间:2016-11-10 23:46:14

标签: ruby-on-rails ruby postgresql ruby-on-rails-5

我有一张<VirtualHost *:80> DocumentRoot "c:/wamp/www" ServerName localhost ServerAlias localhost <Directory "c:/wamp/www"> Options Indexes FollowSymLinks AllowOverride All Require local </Directory> </VirtualHost> <VirtualHost *:80> ServerAdmin info@mywebsite.com DocumentRoot "c:/wamp/www/mywebsite" ServerName mywebsite.com ServerAlias www.mywebsite.com ErrorLog "logs/mywebsite-error.log" CustomLog "logs/mywebsite-access.log" common </VirtualHost> 的表,其Albums列名为date

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

因此,输出可能类似于:

  • 2016年11月 - 11
  • 2016年10月 - 4
  • 2016年7月 - 19
  • 2015年12月 - 2

Ruby 2.3.1 w / Rails 5 on Postgres 9.6,FWIW。

2 个答案:

答案 0 :(得分:5)

数据库层是这个任务所属的地方,而不是Ruby:

Album.group("TO_CHAR(release_date, 'Month YYYY')").count

为什么要使用数据库层?仅仅因为它与其他任何东西相比都闪电般快,与Ruby相比它具有资源效率特别,它完美地扩展,因为拥有大量的Album记录,你可以简单地超载内存而且永远不会实际上完成了处理。

答案 1 :(得分:1)

我假设你的表是每个Rails约定的单Album。如果没有,请考虑更改它。

 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方法是一种标准计数算法,它返回一个带有每个唯一数组项的计数的哈希值。