mysql - 在数据库之间复制表

标签 mysql sql ruby-on-rails database ruby-on-rails-3

我正在使用 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/

相关文章:

php - 从 MySQL 表中获取数据并插入到另一个表中

sql - 如何根据sequelize中的某些列对数据进行排序

mysql - 在 SQL 数据库中创建一个名为 "select"的表

ruby-on-rails - Rails 应用程序保持这么多空闲的 Puma 和 Postgres 连接是否正常?

ruby-on-rails - ruby 语法(rails 模型)

java - 我们需要为Spring Boot中的每个表都编写实体类吗?

迄今为止的 MySQL 字符串(通用)

php - 如何使用 PHP MySQL 在 AJAX 脚本中获取数据库值

sql - Node js mssql 问题 - 改编 mysql 示例

ruby-on-rails - Rails/ActiveRecord : Why does count result in a syntax error when called on my ActiveRecord:Relation?