sql >> Base de Datos >  >> RDS >> Mysql

Rails 3 ActiveRecord:orden por conteo en asociación

Uso de ámbitos con nombre :

class Song
  has_many :listens
  scope :top5,
    select("songs.id, OTHER_ATTRS_YOU_NEED, count(listens.id) AS listens_count").
    joins(:listens).
    group("songs.id").
    order("listens_count DESC").
    limit(5)

Song.top5 # top 5 most listened songs