我有一个模型 Laps,它属于:Car
所以每辆车都有很多圈,但我需要做一个查询,我在哪里拉进前 10 最快圈,但每辆车只拉最快圈。换句话说,我不希望一辆车被允许在列表中的前 10 最快圈中拥有 5 圈。
每圈都有一个 :car_id 字段。我想在此列上分组,然后从分组中拉出带有 min(Lap.time) 行的圈。(也就是那个独特的:car_id 中最快的单圈时间)。
那么对于 Postgres,我最好的方法是什么?我可以先订购所有圈,然后分组,然后从组中拉出第一圈吗?或者分组不会保持排序顺序?
这是我的 Lap 模型架构:
create_table "laps", force: true do |t|
t.decimal "time"
t.string "video_url"
t.integer "car_id"
t.datetime "created_at"
t.datetime "updated_at"
t.integer "user_id"
t.boolean "approved"
end
我必须为此使用两个组合查询吗?
通过这样做,我可以获得一个独特的汽车 ID 圈:
select('DISTINCT ON (car_id) *')
但是,我需要订购圈数,以便它获得每个 car_id 的 min(lap.time)。所以当我发出这样的订单时:
select('DISTINCT ON (car_id) *').order('car_id, time ASC').sort_by! {|ts| ts.time}
这可行,但似乎是一种奇怪的方法。一旦我尝试更改订单,例如从订单中删除 car_id,我就会收到 postgres 错误。