ruby-on-rails - rails : active record saving time:type with unwanted format

标签 ruby-on-rails ruby activerecord time

我有一个名为 periodo 的表,其属性为 hour。我以这种方式传递我的时间参数

hour = Time.parse( splitLine[1] ) #where splitLine[1] is my time but in string
periodo = Periodo.new(:hour => hour.strftime("%H:%M"))
periodo.save

但是active record是这样保存记录的 hour: "2000-01-01 07:00:00",我已经在/config/initializers/time_formats.rb中设置了格式

Time::DATE_FORMATS[:default] = "%H:%M"
Date::DATE_FORMATS[:default] = "%H:%M"

也在 en.yml 中

  en:
    hello: "Hello world"
    time:
      formats:
        default: "%H:%M"
    date:
      formats:
        default: "%H:%M"

但我的记录仍在保存年和月:(我必须做些什么才能只保存小时和分钟???

问候

最佳答案

日期格式仅在您的应用程序中有效,在数据库中无效 - 它们仅负责时间对象向您的用户显示的方式,不会影响数据的存储方式。

不幸的是,数据库中没有时间这样的概念(至少我没有听说过,相信我,我确实搜索过它,因为我在当前项目中需要它)

最简单的解决方案

但是,在许多情况下,只存储事件的时间是有意义的。在当前项目中,我们决定以整数格式存储它 60 * hour + minutes。不幸的是,这是我们在项目中停止的地方。 :(

更进一步

然后您可以创建一个辅助类(只是一个脚手架 - 需要做更多工作,例如验证转换等):

class SimpleTime
  attr_accessor :hour, :minute

  def initialize(hour, minute)
     @hour, @minute = hour, minute
  end

  def self.parse(integer)
    return if integer.blank? 
    new(integer / 60, integer % 60)
  end

  def to_i
    60 * @hour + @minute
  end
end

然后覆盖 setter 和 getter:

class Model < ActiveRecord::Base
  def time
    @time ||= SimpleTime.parse(super)
  end

  def time=(value)
    super(value.to_i)
  end
end

更多乐趣

现在您可以做更多的事情。例如,您可以将扩展名 simple_time 写入 active_record,这将自动为传递的属性列表重新定义 setter 和 getter。您甚至可以将它包装在一个小 gem 中并使其在现实世界中得到证明(缺少验证、字符串格式解析器、处理 _before_type_cast 值等)。

关于ruby-on-rails - rails : active record saving time:type with unwanted format,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30629531/

相关文章:

ruby-on-rails - Rails 未初始化常量名称错误

javascript - facebook 评论(Facebook 社交插件)仅在我刷新 rails 4 应用程序中的页面后加载

ruby-on-rails - RSpec: Controller 规范的多个断言

javascript - 如何使用 Rails Each Array 和页内搜索来显示/隐藏 div 内容

ruby-on-rails - 尝试将本地数据库推送到 Heroku 后出现 "ActionView::Template::Error (Unknown primary key for table"

ruby-on-rails - 关系 belongs_to 上的 activerecord where 子句

ruby - rvm 中每个 ruby​​ 版本的不同 ruby​​gem 版本

ruby - Watir 不适用于 Ruby 1.9.3

mysql - 如何在 FUEL/ActiveRecord 中插入 NULL 值

mysql - Laravel 5 中的复杂查询