如何设置ActiveRecord在访问datetime数据时不自动转换为对象?

2026-04-11 19:574阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计282个文字,预计阅读时间需要2分钟。

如何设置ActiveRecord在访问datetime数据时不自动转换为对象?

我有一些代码,只是访问日期时间字段,因此当我读取它时,`activerecord`会自动将其转换为`Time`对象:`@some_appointment.some_time`。问题是`some_time` datetime列有错误数据。例如,2009-12-20被替换为2009-12-%。

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

@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的独立脚本来检查数据库中的数据以对其进行规范化.这可能比将不良数据的特殊情况编码到您的应用程序中更快.

如何设置ActiveRecord在访问datetime数据时不自动转换为对象?

本文共计282个文字,预计阅读时间需要2分钟。

如何设置ActiveRecord在访问datetime数据时不自动转换为对象?

我有一些代码,只是访问日期时间字段,因此当我读取它时,`activerecord`会自动将其转换为`Time`对象:`@some_appointment.some_time`。问题是`some_time` datetime列有错误数据。例如,2009-12-20被替换为2009-12-%。

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

@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的独立脚本来检查数据库中的数据以对其进行规范化.这可能比将不良数据的特殊情况编码到您的应用程序中更快.

如何设置ActiveRecord在访问datetime数据时不自动转换为对象?