我正在开发一个非Rails网络应用程序,因此默认情况下没有迁移脚本。
续集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是否有办法解决这个问题?
答案 0 :(得分:21)
我目前的理解是否定的,所有修改数据或架构都必须通过迁移来完成。我有a complete rakefile on 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
答案 1 :(得分:13)
至少在Rails 4中(可能更早?),您可以使用与迁移相同的语法直接在ActiveRecord::ConnectionAdapters
实例上调用create table。
通过调用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
,因为它输入的次数较少。