【发布时间】:2011-11-24 14:33:00
【问题描述】:
我正在使用 MySQL v5.1。
我正在开发一个 Rails 应用程序。并编写一个 ruby 脚本来复制数据库。到目前为止,我得到了一个表名数组,表的数量是 2090。我需要在一个新的数据库中创建所有表,我的代码如下所示:
#"table_names" is fetched by execute 'show tables' SQL commands
table_names.each { |tbl_name|
ActiveRecord::Base.connection.execute("CREATE TABLE #{new_db_name}.#{tbl_name} LIKE #{old_db_name}.#{tbl_name}")
}
这段代码可以运行,但是完成的时间比较长,因为代码要一个一个执行CREATE TABLE命令,要创建2090个表。
我想知道有什么方法可以在 SQL 中批量创建表(如批量插入数据)以节省时间?如果没有,如何提高创建表的速度?这就是将所有 2090 个表从一个数据库复制到另一个数据库。
P.S.我不想在 SQL 文件中硬编码所有 2090 表名。
【问题讨论】:
标签: mysql sql ruby-on-rails database ruby-on-rails-3