我有一些代码只是访问日期时间字段,因此当我读取它时,activerecord会自动将其转换为Time对象: @some_appointment.some_time 问题是有时“some_time”datetime列有坏数据. “0209-12-20”代替“2009-12-
@some_appointment.some_time
问题是有时“some_time”datetime列有坏数据. “0209-12-20”代替“2009-12-20”.这导致Ruby只是从访问中抛出“年份太大而无法编组”错误,而我似乎无法捕获它,因为错误不是例外.鉴于我的数据库中存在一些无效数据,我想通过读取日期时间字符串并使用Time.parse来尝试自己创建时间对象,这样如果无法解析时间,我就可以捕获异常.我怎么能做到这一点?有没有更好的办法?
您可以尝试attribute_for_inspect,如:SomeModel.find(:first).attribute_for_inspect 'some_time' #=> ""2009-02-23 23:15:24""
您可能还会考虑编写一个不使用activerecord的独立脚本来检查数据库中的数据以对其进行规范化.这可能比将不良数据的特殊情况编码到您的应用程序中更快.