sql >> Databáze >  >> RDS >> PostgreSQL

Problémy s nekonečným časovým rozsahem v Rails

Nemůžete uložit Infinity jako součást časového rozsahu v Rails. Věřím, že je to proto, že Infinity bude vloženo jako hodnota řetězce a interpretováno jako float, když se vytáhne z nativního PSQL oidu. Takže žádné časové období z Date -> Float nebude životaschopné. Můžete si však vytvořit vlastní rozsah s pseudo (1 milion let od nynějška) daty nebo můžete použít dvě samostatná pole data a vhodně je interpretovat v modelu. Datum zahájení, datum ukončení.

V Rails 4.2+ můžete uložit hodnotu Float::INFINITY do vašeho typu datetime. Příklad.

User.first.update(begin_date: DateTime.now, end_date: 'infinity')
User.first.end_date # => Infinity

Nicméně end_date nebude platné datum. Právě ukládáte řetězec v databázi a vytahujete float když to zavoláte.

Zde je skutečný (Rails 4.2) kód, který to řeší:

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

Opět nebudete být schopen provádět srovnání data a času s plovoucím zařízením. Pravděpodobně je ale dost jednoduché mít speciální případ pro tyto dvě hodnoty -::Float::INFINITY a ::Float::INFINITY




  1. Úloha Oracle DBMS neběží

  2. Oracle NLS_DATE_FORMAT nefunguje správně

  3. Detekce, odstranění prázdných sloupců a aktualizace databáze v SQL, Oracle

  4. Export dat z databáze v php a formát souboru pro export do Excelu by měl být jako sešit Windows 97-2003