我已经有了一个有效的解决方案,但我真的很想知道为什么这行不通:

ratings = Model.select(:rating).uniq
ratings.each { |r| puts r.rating }

它选择,但不打印唯一值,而是打印所有值,包括重复的值。它在文档中:http://guides.rubyonrails.org/active_record_querying.html#selecting-specific-fields


当前回答

这也有用。

Model.pluck("DISTINCT rating")

其他回答

您可以使用以下Gem: active_record_distinct_on

Model.distinct_on(:rating)

产生以下查询:

SELECT DISTINCT ON ( "models"."rating" ) "models".* FROM "models"

有些答案没有考虑到OP需要一个值数组

如果您的Model有数千条记录,其他答案就不能很好地工作

也就是说,我认为一个很好的答案是:

    Model.uniq.select(:ratings).map(&:ratings)
    => "SELECT DISTINCT ratings FROM `models` " 

因为,首先生成一个Model数组(由于选择而减小了大小),然后提取那些所选模型的唯一属性(评级)

如果你要使用模型。select,那么你可能只使用DISTINCT,因为它只会返回唯一的值。这样更好,因为这意味着它返回更少的行,并且应该比返回一些行然后告诉Rails选择惟一值略快。

Model.select('DISTINCT rating')

当然,前提是您的数据库能够理解DISTINCT关键字,而且大多数数据库都应该理解。

如果你还想选择额外的字段:

Model.select('DISTINCT ON (models.ratings) models.ratings, models.id').map { |m| [m.id, m.ratings] }

用sql收集uniq列的另一种方法:

Model.group(:rating).pluck(:rating)