Может ли ActiveRecord создавать таблицы вне миграции? - PullRequest
11 голосов
/ 01 марта 2010

Я работаю над веб-приложением, отличным от Rails, поэтому по умолчанию сценарий миграции отсутствует.

Sequel ORM позволяет мне легко создавать таблицы в скрипте:

#!/usr/bin/env ruby

require 'rubygems'
require 'sequel'

## Connect to the database
DB = Sequel.sqlite('./ex1.db')

unless DB.table_exists? :posts
  DB.create_table :posts do
    primary_key :id
    varchar :title
    text :body
  end
end

Есть ли способ сделать это с ActiveRecord вне миграции?

Ответы [ 2 ]

21 голосов
/ 03 апреля 2010

Насколько я понимаю, нет, все данные или схемы изменений должны быть выполнены путем миграции. У меня полный rakefile на github , который можно использовать для выполнения миграции вне Rails.

В качестве альтернативы, если это просто скрипт инициализации, можно использовать следующее.

ActiveRecord::Base.establish_connection(
   :adapter   => 'sqlite3',
   :database  => './lesson1_AR.db'
)

ActiveRecord::Migration.class_eval do
  create_table :posts do |t|
        t.string  :title
        t.text :body
   end

   create_table :people do |t|
      t.string :first_name
      t.string :last_name
      t.string :short_name
   end

   create_table :tags do |t|
      t.string :tags
   end 
end
13 голосов
/ 11 декабря 2014

По крайней мере, в Rails 4 (возможно, раньше?) Вы можете вызвать создать таблицу непосредственно на экземпляре ActiveRecord::ConnectionAdapters, используя тот же синтаксис, что и при миграции.

Вы можете получить соединение для вашей базы данных (при условии, что у вас есть только одна база данных), позвонив по номеру ActiveRecord::Base.connection. Итак, Ruby для вашего примера будет выглядеть так:

unless ActiveRecord::Base.connection.table_exists?(:posts)
  ActiveRecord::Base.connection.create_table :posts do |t|
    # :id is created automatically
    t.string :title
    t.text :body
  end
end

Примечание. Если модель уже определена и она использует ту же базу данных, что и база данных, в которой вы хотите создать таблицу, вы можете вместо этого получить объект подключения. Для создания одноразовой таблицы в консоли я позвоню User.connection.create_table просто потому, что она меньше печатает.

...