我正在使用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个表名。
我知道mysqldump的方式,但我不需要表中的数据,这就是为什么我不使用转储。不过谢谢你。 –
它也有一个--no-data选项,它只转储表结构/触发器/程序/等等......基本上除了数据以外的所有东西。 –