2011-11-24 81 views
0

我正在使用MySQL v5.1。数据库之间的复制表

我正在开发一个Rails应用程序。并编写一个红宝石脚本来复制数据库。到目前为止,我有表名称的数组,表的数量是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个表名。

回答

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查询重建数据库以及禁用外键以及不会导致任何外键问题而在恢复的DB处于中途状态时加载转储。

+0

我知道mysqldump的方式,但我不需要表中的数据,这就是为什么我不使用转储。不过谢谢你。 –

+2

它也有一个--no-data选项,它只转储表结构/触发器/程序/等等......基本上除了数据以外的所有东西。 –

0

声音就像你正在寻找的是SchemaCompare工具,而不是DataCompare工具。这是内置于Visual Studio for SQL。这个工具将这样做:http://toadformysql.com/index.jspa

+0

对不起,我不想为此使用任何外部工具,但谢谢。 –