我正在使用 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 个表从一个数据库复制到另一个数据库。
附言我不想在 SQL 文件中对所有 2090 个表名进行硬编码。
最佳答案
在 mysql 中最简单的方法是对有问题的数据库执行 mysqldump
,然后将其恢复到新数据库,例如:
mysql_dump -pPASSWORD -uUSERNAME name_of_db > name_of_db.sql
mysql -pPASSWORD -uUSERNAME name_of_db < name_of_db.sql
转储文件将包含重新创建数据库所需的所有 DDL/DML 查询,以及禁用外键和诸如此类的东西,以便在恢复的数据库处于半途状态时可以加载转储而不会导致任何外键问题。
关于mysql - 在数据库之间复制表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8258680/