我正在使用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个表名。
答案 0 :(得分:4)
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查询,以及禁用外键等等,以便在恢复的数据库处于中途状态时可以加载转储而不会导致任何外键问题。 / p>
答案 1 :(得分:0)
听起来你正在寻找的是SchemaCompare工具,而不是DataCompare工具。这内置于Visual Studio for SQL中。该工具将执行此操作:http://toadformysql.com/index.jspa