Ruby MySQL数据库迁移脚本

时间:2016-10-22 17:25:48

标签: mysql ruby-on-rails ruby database database-migration

我对ruby完全不熟悉,我想为MySQL数据库创建数据库迁移脚本。我浏览了在线资料,我必须创建一个应用程序才能创建迁移脚本。

我可以在单个文件中编写数据库迁移脚本,执行以下任务:

  1. 创建数据库
  2. 创建2-3个表
  3. 在这些表格中播种一些数据
  4. 任何帮助或参考都会很棒

    提前致谢

1 个答案:

答案 0 :(得分:0)

您只能使用一个宝石 mysql2 - https://stackoverflow.com/a/14435522/3102718

使用 activerecord

mysql2

以下是迁移文件的示例:

<强> create_database.rb

require 'mysql2'

client = Mysql2::Client.new(host: 'localhost', username: 'root')
client.query("CREATE DATABASE my_database")

require 'active_record'

class CreateUsers < ActiveRecord::Migration
  def self.up
    create_table :users do |t|
      t.string :name
      t.string :email
    end

    add_index :users, :email, unique: true
  end
end

class CreatePosts < ActiveRecord::Migration
  def self.up
    create_table :posts do |t|
      t.references :user, index: true
      t.string :title
      t.text :body
    end
  end
end

ActiveRecord::Base.establish_connection(
  adapter: 'mysql2',
  encoding: 'utf8',
  host: 'localhost',
  database: 'my_database',
  username: 'root',
  socket: '/tmp/mysql.sock'
)

CreateUsers.up
CreatePosts.up

class User < ActiveRecord::Base
  has_many :posts
end

class Post < ActiveRecord::Base
  belongs_to :user
end

user = User.create(email: "test@example.com", name: "User")
user.posts.create(title: "My Post", body: "Lorem ipsum")

使用$ ruby create_database.rb运行它 (应安装gems mysql2activerecord。)