Где находится страница документации для типов данных ActiveRecord? - PullRequest
72 голосов
/ 18 октября 2010

Я не могу найти страницу с документацией активной записи, в которой есть список всех типов данных.

Может ли кто-нибудь мне помочь?

Ответы [ 4 ]

105 голосов
/ 18 октября 2010

Если вы говорите о типах миграции, например, строка, целое число, дата и т. д., затем вы хотите ActiveRecord :: ConnectionAdapters :: TableDefinition , столбец метод (Rails 5 edit: см. Также соединение. add_column .)

Начиная с этого обновления, стандартные типы:

  • :primary_key
  • :string
  • :text
  • :integer
  • :bigint
  • :float
  • :decimal
  • :numeric
  • :datetime
  • :time
  • :date
  • :binary
  • :boolean

Реализация :decimal отличается для каждой базы данных, поэтому я бы ее избегал, если это возможно. Вы можете использовать тип, которого нет в этом списке, если он поддерживается вашей базой данных (например, :polygon в MySQL), но это не будет независимым от базы данных, и его также следует избегать.

6 голосов
/ 24 июня 2013

Вы также можете видеть типы данных ActiveRecord в источниках.Каждый адаптер СУБД содержит свое собственное отображение.Например, в случае MySQL посмотрите на этот файл: https://github.com/rails/rails/blob/master/activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb#L148 или получите его по этой строке кода для текущего адаптера СУБД:

ActiveRecord::Base.connection.native_database_types.keys
5 голосов
/ 23 января 2015

Вот сопоставления типов по умолчанию для адаптеров базы данных:

enter image description here enter image description here

4 голосов
/ 13 февраля 2015

Обратите внимание, что это основано на Исходном коде Rails от 13 февраля 2015 г. (Rails 4.2)

На случай, если кто-то захочет увидеть, как эти типы данных отображаются в используемую вами базу данных.

Вы можете легко получить исходный код rails на github.

Например,

Rails типы данных дляmysql datatyes mapping.

NATIVE_DATABASE_TYPES = {
        :primary_key => "int(11) auto_increment PRIMARY KEY",
        :string      => { :name => "varchar", :limit => 255 },
        :text        => { :name => "text" },
        :integer     => { :name => "int", :limit => 4 },
        :float       => { :name => "float" },
        :decimal     => { :name => "decimal" },
        :datetime    => { :name => "datetime" },
        :time        => { :name => "time" },
        :date        => { :name => "date" },
        :binary      => { :name => "blob" },
        :boolean     => { :name => "tinyint", :limit => 1 }
      }

Найден на https://github.com/rails/rails/blob/master/activerecord/lib/active_record/connection_adapters/abstract_mysql_adapter.rb#L148

И если кто-то захочет использовать PostgreSQL, вы идете.

NATIVE_DATABASE_TYPES = {
        primary_key: "serial primary key",
        bigserial: "bigserial",
        string:      { name: "character varying" },
        text:        { name: "text" },
        integer:     { name: "integer" },
        float:       { name: "float" },
        decimal:     { name: "decimal" },
        datetime:    { name: "timestamp" },
        time:        { name: "time" },
        date:        { name: "date" },
        daterange:   { name: "daterange" },
        numrange:    { name: "numrange" },
        tsrange:     { name: "tsrange" },
        tstzrange:   { name: "tstzrange" },
        int4range:   { name: "int4range" },
        int8range:   { name: "int8range" },
        binary:      { name: "bytea" },
        boolean:     { name: "boolean" },
        bigint:      { name: "bigint" },
        xml:         { name: "xml" },
        tsvector:    { name: "tsvector" },
        hstore:      { name: "hstore" },
        inet:        { name: "inet" },
        cidr:        { name: "cidr" },
        macaddr:     { name: "macaddr" },
        uuid:        { name: "uuid" },
        json:        { name: "json" },
        jsonb:       { name: "jsonb" },
        ltree:       { name: "ltree" },
        citext:      { name: "citext" },
        point:       { name: "point" },
        bit:         { name: "bit" },
        bit_varying: { name: "bit varying" },
        money:       { name: "money" },
      }
...