Railsの時間範囲の一部としてInfinityを保存することはできません。これは、Infinityが文字列値として挿入され、ネイティブPSQLOIDから引き出されたときにfloatとして解釈されるためだと思います。したがって、[日付]->[フロート]の日付範囲は実行できません。ただし、疑似(100万年後)の日付を使用して独自の範囲を作成することも、2つの別々の日付フィールドを使用してモデルで適切に解釈することもできます。開始日、終了日。
Rails 4.2以降では、日時タイプ内にFloat::INFINITY値を格納できます。例。
User.first.update(begin_date: DateTime.now, end_date: 'infinity')
User.first.end_date # => Infinity
ただし、end_date
有効な日付ではありません。 文字列を保存しているだけです データベースにあり、フロートを引き出しています。 あなたがそれを呼ぶとき。
これを処理する実際の(Rails 4.2)コードは次のとおりです。
module ActiveRecord
module ConnectionAdapters
module PostgreSQL
module OID # :nodoc:
class DateTime < Type::DateTime # :nodoc:
include Infinity
def type_cast_for_database(value)
if has_precision? && value.acts_like?(:time) && value.year <= 0
bce_year = format("%04d", -value.year + 1)
super.sub(/^-?\d+/, bce_year) + " BC"
else
super
end
end
def cast_value(value)
if value.is_a?(::String)
case value
when 'infinity' then ::Float::INFINITY
when '-infinity' then -::Float::INFINITY
when / BC$/
astronomical_year = format("%04d", -value[/^\d+/].to_i + 1)
super(value.sub(/ BC$/, "").sub(/^\d+/, astronomical_year))
else
super
end
else
value
end
end
end
end
end
end
end
繰り返しますが、しません フロートを使用して日時の比較を行うことができます。ただし、これら2つの値-::Float::INFINITY
に特別なケースを設定するのはおそらく簡単です。 および::Float::INFINITY