Rails/SQL:如何在特定 id 上查找最频繁的列值

Posted

技术标签:

【中文标题】Rails/SQL:如何在特定 id 上查找最频繁的列值【英文标题】:Rails/SQL: How to find the most frequent column value on a specific 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 子句或在聚合函数中使用

这应该怎么做?

【问题讨论】:

【参考方案1】:

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

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

【讨论】:

欢迎@dcporter7

以上是关于Rails/SQL:如何在特定 id 上查找最频繁的列值的主要内容,如果未能解决你的问题,请参考以下文章

如何根据Python中另一列中的日期查找最频繁的值

如何查找 jQuery 中是不是存在具有特定 id 的 div?

在 Spark 数据框中的 n 列中按行查找最频繁的值

Python:如何找到最频繁的元素组合?

通过聚合在pandas组中查找频繁项的最有效方法是啥[重复]

为啥在大型数据库上查找具有特定 ID 的对象的 Django 查询比在较小数据库上要慢?