У меня есть таблица валют, и я хочу захватить все значения со значением даты в течение 1 недели.Я выполнил этот запрос и смог получить результат:
Currency.where (date: (1.week.ago..Date.today.end_of_day)
Это поле даты является датой-временем.
Теперь я хочу получить только запись с самой высокой датой, записанной в день.То есть я хочу получить 7 записей (по одной на каждый день недели), и эта запись является последней записанной (наибольшее значение в столбце даты) этого конкретного дня.
Как мне сделать этот запросв активной записи?
Я пытался использовать date_trunc, но мне это не удалось.Моя база данных - postgresql
DLL таблицы:
Валюта (id: целое число, currency_kind: целое число, значение: число с плавающей точкой, дата: datetime, create_at: datetime, updated_at: datetime)
class CreateCurrencies < ActiveRecord::Migration[5.2]
def change
create_table :currencies do |t|
t.integer :currency_kind
t.float :value
t.datetime :date
t.timestamps
end
end
end
Пример с Currency.all
=> #<ActiveRecord::Relation [#<Currency id: 51, currency_kind: "eur", value: 4.18835, date: "2019-02-04 05:37:59", created_at: "2019-02-04 03:08:08", updated_at: "2019-02-04 03:08:08">, #<Currency id: 52, currency_kind: "usd", value: 3.6593, date: "2019-02-04 05:37:59", created_at: "2019-02-04 03:08:08", updated_at: "2019-02-04 03:08:08">, #<Currency id: 53, currency_kind: "aud", value: 2.65061, date: "2019-02-04 05:37:59", created_at: "2019-02-04 03:08:08", updated_at: "2019-02-04 03:08:08">, #<Currency id: 54, currency_kind: "eur", value: 4.18755, date: "2019-02-04 02:47:58", created_at: "2019-02-04 03:18:13", updated_at: "2019-02-04 03:18:13">, #<Currency id: 55, currency_kind: "usd", value: 3.6593, date: "2019-02-04 02:47:59", created_at: "2019-02-04 03:18:13", updated_at: "2019-02-04 03:18:13">, #<Currency id: 56, currency_kind: "aud", value: 2.6497, date: "2019-02-04 02:47:59", created_at: "2019-02-04 03:18:13", updated_at: "2019-02-04 03:18:13">, #<Currency id: 57, currency_kind: "eur", value: 4.19655, date: "2019-02-04 22:55:59", created_at: "2019-02-04 23:26:40", updated_at: "2019-02-04 23:26:40">, #<Currency id: 58, currency_kind: "usd", value: 3.6692, date: "2019-02-04 22:55:59", created_at: "2019-02-04 23:26:40", updated_at: "2019-02-04 23:26:40">, #<Currency id: 59, currency_kind: "aud", value: 2.6499, date: "2019-02-04 22:55:59", created_at: "2019-02-04 23:26:40", updated_at: "2019-02-04 23:26:40">, #<Currency id: 60, currency_kind: "eur", value: 4.1943, date: "2019-02-04 23:27:02", created_at: "2019-02-04 23:27:09", updated_at: "2019-02-04 23:27:09">, ...]>