gpt4 book ai didi

ruby-on-rails - 铁路 TimeWithZone 与日期

转载 作者:太空宇宙 更新时间:2023-11-03 16:24:29 27 4
gpt4 key购买 nike

我的模型中有这个方法:

def date_ranges
reservations = Reservation.where(["transport_id =?", transport_id])
reservations = reservations.where(['id <> ?', id]) if !id.nil?
reservations.map { |e| e.reservation_start..e.reservation_end }
end

它工作得很好(感谢 StackOverflow 的一些帮助)。

我的 reservation_startreservation_end 列是 date 类型。这是我的迁移:

class CreateReservations < ActiveRecord::Migration
def change
create_table :reservations do |t|
t.references :user, index: true
t.references :transport, index: true

t.date :reservation_start
t.date :reservation_end
t.timestamps
end
end
end

如果我在从 date 列类型迁移到 datetime 类型后尝试运行此方法,我会收到错误消息:

can't iterate from ActiveSupport::TimeWithZone

即使我将方法中的代码更改为:它也不会工作:

reservations.map do |e|
e.reservation_start.to_datetime..e.reservation_end.to_datetime
end

最佳答案

不幸的是,如果您想迭代 DateTime 范围,则该范围的粒度至少应为 1 天。因此,看起来错误出在您使用#date_ranges 的地方,而不是方法本身

由于您使用的是 ActiveSupport::TimeWithZone(这是您在使用 datetime SQL 类型时获得的对象类型),您得到的不仅仅是约会——你也有时间。

所以取决于你如何使用该方法。

您有两种选择来解决此问题:

  1. 将代码更改为以下内容:

     reservations.map do |e|
    e.reservation_start.to_date..e.reservation_end.to_date
    end

    这样你会失去时间精度,只能回溯到日期。

  2. 改变您使用#date_ranges 方法的方式。最好的办法可能是让它返回 [begin_date, end_date] 数组。

     def date_ranges
    Reservation.where(transport_id: transport_id).pluck(:reservation_start, :reservation_end)
    end

    根据您使用范围的方式,您可以弄清楚:

    • 如果您要检查特定时间是否在任何给定日期范围内,您可以这样做:

      date_ranges.any? { |date_range| date_range.cover?(my_time) }
    • 如果您要显示日期:

      date_ranges.each do |date_range|
      # display the date range
      end

关于ruby-on-rails - 铁路 TimeWithZone 与日期,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27546680/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com