我正在创建一个 Rails 3.2 应用程序,但我不确定如何处理日期和时间。现在我在数据库中有一个名为 start_date 的字段,这是一个日期时间时间戳,我还有一个名为 start_time 的字段。
我正在使用完整的日历插件,要使其正常工作,我必须将start_date和start_time结合起来。我该怎么做?(并非数据库中的所有事件都有start_time)。
感谢所有输入!
Ruby有DateTime
类,它基本上将日期和时间合并到一个对象中。我建议进行迁移,创建一个名为start
的新字段,然后将现有的start_date
和start_time
字段合并为一个:
def up
add_column :events, :start, :datetime
Event.find_each do |e|
d = e.start_date
t = e.start_time
e.start = DateTime.new(d.year, d.month, d.day, t.hour, t.min, t.sec)
end
remove_column :events, :start_date
remove_column :events, :start_time
end
def down
add_column :events, :start_date, :datetime
add_column :events, :start_time, :datetime
Event.find_each do |e|
s = e.start
e.start_date = s.to_date
e.start_time = s.to_time
end
remove_column :events, :start
end
如果你需要在将来获取日期或时间组件,你可以使用to_date
或to_time
,组合DateTime
应该可以很好地与全日历配合使用。