Используйте active record для поиска записей по месяцам и дням, игнорируя год и время



У меня есть модель (записи) с записями за пять лет (одна запись в день). Мне нужен метод, который при передаче объекта даты, такого как 2011-12-25 00:00:00, покажет мне все записи, которые произошли на 12/25 (запрос к столбцу :created_at), независимо от года или времени, которое прошло.



RoR 3.0.9 / Ruby 1.9. 2p290

826   4  

4 ответов:

Вы можете использовать значения месяца и дня mysql. Может быть, что-то вроде:

Model.where("MONTH(created_at) = ? and DAY(created_at) = ?", somedate.month, somedate.day)

Общее решение, которое должно работать с большинством баз данных SQL (включая MySQL и PostgreSQL):

Entry.where('extract(month from created_at) = ? AND extract(day from created_at) = ?', d.month, d.day)

SQLite не понимает extract, хотя вам придется использовать:

Entry.where("strftime('%m/%d', created_at) = ?", d.strftime('%m/%d'))

Предполагая, что вы используете mysql:

User.where(["DAY(created_at) = ? AND MONTH(created_at) = ?", date.day, date.month])

Предположим, что СУБД-это MySQL, и у вас есть форма с combobox для выбора месяца и / или date_of_months, может быть, вы могли бы сделать named_scope, например:

scope :by_date_or_month, lambda { |date, month| {:conditions => ["DAYOFMONTH(created_at) = ? or MONTH(created_at) = ?", date, month]}}

ТЕСТ от IRB:

Model.by_date_or_month(31,8)
Model.by_date_or_month(nil,8)

Comments

    Ничего не найдено.