我已经有了一个有效的解决方案,但我真的很想知道为什么这行不通:
ratings = Model.select(:rating).uniq
ratings.each { |r| puts r.rating }
它选择,但不打印唯一值,而是打印所有值,包括重复的值。它在文档中:http://guides.rubyonrails.org/active_record_querying.html#selecting-specific-fields
我已经有了一个有效的解决方案,但我真的很想知道为什么这行不通:
ratings = Model.select(:rating).uniq
ratings.each { |r| puts r.rating }
它选择,但不打印唯一值,而是打印所有值,包括重复的值。它在文档中:http://guides.rubyonrails.org/active_record_querying.html#selecting-specific-fields
当前回答
Model.select(:rating)
这样做的结果是Model对象的集合。不是简单的评级。从uniq的角度来看,它们是完全不同的。你可以用这个:
Model.select(:rating).map(&:rating).uniq
或者这样(最有效):
Model.uniq.pluck(:rating)
Rails 5 +
Model.distinct.pluck(:rating)
更新
显然,从rails 5.0.0.1开始,它只能在“顶级”查询上工作,就像上面那样。不能在集合代理上工作(例如,“has_many”关系)。
Address.distinct.pluck(:city) # => ['Moscow']
user.addresses.distinct.pluck(:city) # => ['Moscow', 'Moscow', 'Moscow']
在这种情况下,请在查询后进行重复数据删除
user.addresses.pluck(:city).uniq # => ['Moscow']
其他回答
Model.select(:rating)
这样做的结果是Model对象的集合。不是简单的评级。从uniq的角度来看,它们是完全不同的。你可以用这个:
Model.select(:rating).map(&:rating).uniq
或者这样(最有效):
Model.uniq.pluck(:rating)
Rails 5 +
Model.distinct.pluck(:rating)
更新
显然,从rails 5.0.0.1开始,它只能在“顶级”查询上工作,就像上面那样。不能在集合代理上工作(例如,“has_many”关系)。
Address.distinct.pluck(:city) # => ['Moscow']
user.addresses.distinct.pluck(:city) # => ['Moscow', 'Moscow', 'Moscow']
在这种情况下,请在查询后进行重复数据删除
user.addresses.pluck(:city).uniq # => ['Moscow']
Model.uniq.pluck(:rating)
# SELECT DISTINCT "models"."rating" FROM "models"
这具有不使用sql字符串和不实例化模型的优点
如果你还想选择额外的字段:
Model.select('DISTINCT ON (models.ratings) models.ratings, models.id').map { |m| [m.id, m.ratings] }
Model.pluck("DISTINCT column_name")
您可以使用以下Gem: active_record_distinct_on
Model.distinct_on(:rating)
产生以下查询:
SELECT DISTINCT ON ( "models"."rating" ) "models".* FROM "models"