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