I try to fulfill a request for all stations and join the Measures
But I need only the latest measure (ordered by create_at DESC), since the station has thousands of measures.
I tried
Station.joins(:measures).limit(1)
but it just limits the stations.
Additional Information:
The station has many measures.
Measurement refers to Station
I read Active Records docs , and there is only information about using the where clause for associations.
The application is only for Postgres, SQL accepted.
Edit: added with the exception of schema.rb:
create_table "measures", force: true do |t| t.integer "station_id" t.float "speed" t.float "direction" t.float "max_wind_speed" t.float "min_wind_speed" t.float "temperature" t.datetime "created_at" t.datetime "updated_at" t.float "speed_calibration" end add_index "observations", ["created_at"], name: "index_observations_on_created_at", using: :btree add_index "observations", ["station_id"], name: "index_observations_on_station_id", using: :btree create_table "stations", force: true do |t| t.string "name" t.string "hw_id" t.float "latitude" t.float "longitude" t.float "balance" t.boolean "offline" t.string "timezone" t.integer "user_id" t.datetime "created_at" t.datetime "updated_at" t.string "slug" t.boolean "show", default: true t.float "speed_calibration", default: 1.0 t.datetime "last_observation_received_at" end
Addendum This is the most hash code currently in use:
def all_with_latest_measure if user_signed_in? && current_user.has_role?(:admin) stations = Station.all.load end stations ||= Station.where(show: true).load if stations.size ids = stations.map { |s| s.id }.join(',') where = "WHERE m.station_id IN(#{ids})" unless ids.empty? measures = Measure.find_by_sql(%Q{ SELECT DISTINCT ON(m.station_id, m.created_at) m.* FROM measures m #{where} ORDER BY m.created_at DESC }) stations.each do |station|