ActiveRecord可以在迁移之外创建表吗?

Mor*_*gan 12 sql database orm activerecord create-table

我正在开发一个非Rails Web应用程序,因此默认情况下没有迁移脚本.

续集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
Run Code Online (Sandbox Code Playgroud)

在迁移之外有没有办法使用ActiveRecord?

Mor*_*gan 21

我目前的理解是否定的,所有修改数据或模式都必须通过迁移来完成.我在github上一个完整的rakefile,可用于在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
Run Code Online (Sandbox Code Playgroud)


Cra*_*ker 13

至少在Rails 4中(可能更早?),您可以使用与迁移相同的语法直接在实例上调用create tableActiveRecord::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
Run Code Online (Sandbox Code Playgroud)

注意:如果已经定义了模型,并且它使用与要创建表的数据库相同的数据库,则可以从中获取连接对象.对于在控制台中创建一次性表格,我User.connection.create_table只会因为打字较少而打电话.