Вопрос

В Ruby я пытаюсь сделать следующее.

def self.stats(since)
  return Events.find(:all, :select => 'count(*) as this_count', :conditions => ['Date(event_date) >= ?', (Time.now - since)]).first.this_count
end

где " с тех пор " является строкой, представляющей количество времени («1 час», «1 день», «3 дня») и т. д. Есть предложения?

Это было полезно?

Решение

Я взломал это вместе с гемом ActiveSupport:

require 'active_support'

def string_to_date(date_string)
  parts = date_string.split
  return parts[0].to_i.send(parts[1])
end
sinces = ['1 hour', '1 day', '3 days']

sinces.each do |since|
  puts "#{since} ago: #{string_to_date(since).ago(Time.now)}"
end

[править] Чтобы ответить на ваш вопрос, вы можете попробовать это так:

:conditions => ['Date)event_date) >= ?', (string_to_date(since).ago(Time.now))]

Другие советы

Попробуйте использовать Chronic для анализа строк даты в реальных объектах datetime.

Я согласен с Джоном Милликиным . Chronic или даже ваши собственные помощники будут гораздо более легкой и эффективной зависимостью для переноса, чем вся ActiveSupport, при условии, что вы еще не оказались в ловушке внутри Rails.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top