我可以告诉activerecord在我访问时不将“datetime”数据转换为对象吗?

时间:2010-01-05 00:13:18

标签: ruby-on-rails datetime activerecord

我有一些代码只是访问日期时间字段,因此当我读取它时,activerecord会自动将其转换为Time对象:

@some_appointment.some_time

问题是有时“some_time”datetime列有坏数据。 “0209-12-20”代替“2009-12-20”。这导致Ruby只是从访问中抛出“年份太大而无法编组”错误,而我似乎无法捕获它,因为错误不是例外。鉴于我的数据库中存在一些无效数据,我想通过读取日期时间字符串并使用Time.parse来尝试自己创建时间对象,这样如果无法解析时间,我就可以捕获异常。我怎么能做到这一点?有没有更好的办法?

3 个答案:

答案 0 :(得分:3)

您可以尝试attribute_for_inspect,如:

SomeModel.find(:first).attribute_for_inspect 'some_time'
#=> ""2009-02-23 23:15:24""

您可能还会考虑编写一个不使用activerecord的独立脚本来检查数据库中的数据以对其进行规范化。这可能比将不良数据的特殊情况编码到您的应用程序中更快。

答案 1 :(得分:3)

我没有对此进行测试以确定它是否有效,但您是否尝试过attributes_before_type_cast?它在Rails运行类型转换之前返回数据,但我不确定Rails是否会在加载对象时尝试进行转换。

示例:

@some_appointment.attributes_before_type_cast['some_time']

答案 2 :(得分:1)

您可以在模型中覆盖这样的默认访问者:

def some_time
  read_attribute(:some_time)
  rescue
    # Try to parse this guy
    self.some_time_before_type_cast
end