【问题标题】:Rails/SQL: How to find the most frequent column value on a specific idRails/SQL:如何在特定 id 上查找最频繁的列值
【发布时间】:2017-02-27 10:35:11
【问题描述】:

我正在尝试在 Ruby on Rails 的表中查找特定 SongId 的最常见标题。这是我目前所拥有的:

SongDetail.where(song_id: id).group('title').order('COUNT(*) DESC').first[:title]

我不断收到一条错误消息:

PG::GroupingError: ERROR: column "song_details.id" 必须出现在 GROUP BY 子句或在聚合函数中使用

这应该怎么做?

【问题讨论】:

    标签: sql ruby-on-rails ruby postgresql orm


    【解决方案1】:

    Group by 会将您的记录与不同的列分组,但在您的查询中,postgres 会混淆从title 组中选择哪个song_details.id,因此摆脱以下是技巧

    SongDetail.where(song_id: id).group('title').order('COUNT(*) DESC').select('title').limit(1)
    

    【讨论】:

    • 欢迎@dcporter7
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-12-09
    • 2013-11-27
    • 2017-04-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-04-30
    相关资源
    最近更新 更多