我有一个名为 av2web 的数据库,其中包含 130 个 MyISAM 表和 20 个 innodb 表。我想从这 20 个 innodb 表中取出 mysqldump,并将其作为 MyISAM 表导出到另一个数据库。
你能告诉我一个更快的方法来实现这一点吗?
感谢佩德罗·阿尔瓦雷斯·埃斯皮诺萨。
如果这是一次性手术,我会这样做:
use DB;
show table status name where engine='innodb';
并从名称列进行矩形复制/粘贴:
+-----------+--------+---------+------------+-
| Name | Engine | Version | Row_format |
+-----------+--------+---------+------------+-
| countries | InnoDB | 10 | Compact |
| foo3 | InnoDB | 10 | Compact |
| foo5 | InnoDB | 10 | Compact |
| lol | InnoDB | 10 | Compact |
| people | InnoDB | 10 | Compact |
+-----------+--------+---------+------------+-
到文本编辑器并将其转换为命令
mysqldump -u USER DB countries foo3 foo5 lol people > DUMP.sql
然后在将DUMP.sql 中的所有实例替换为ENGINE=InnoDB
with后导入ENGINE=MyISAM
如果您想避免矩形复制/粘贴魔术,您可以执行以下操作:
use information_schema;
select group_concat(table_name separator ' ') from tables
where table_schema='DB' and engine='innodb';
这将返回countries foo3 foo5 lol people
我知道这是一个老问题。我只想分享这个生成 mysqldump 命令的脚本,并展示如何恢复它
This following portion of the script will generate a command to create a mysql backup/dump
SET SESSION group_concat_max_len = 100000000; -- this is very important when you have lots of table to make sure all the tables get included
SET @userName = 'root'; -- the username that you will login with to generate the dump
SET @databaseName = 'my_database_name'; -- the database name to look up the tables from
SET @extraOptions = '--compact --compress'; -- any additional mydqldump options https://dev.mysql.com/doc/refman/5.6/en/mysqldump.html
SET @engineName = 'innodb'; -- the engine name to filter down the table by
SET @filename = '"D:/MySQL Backups/my_database_name.sql"'; -- the full path of where to generate the backup too
-- This query will generate the mysqldump command to generate the backup
SELECT
CASE WHEN tableNames IS NULL
THEN 'No tables found. Make sure you set the variables correctly.'
ELSE CONCAT_WS(' ','mysqldump -p -u', @userName, @databaseName, tableNames, @extraOptions, '>', @filename)
END AS command
FROM (
SELECT GROUP_CONCAT(table_name SEPARATOR ' ') AS tableNames
FROM INFORMATION_SCHEMA.TABLES
WHERE table_schema= @databaseName AND ENGINE= @engineName
) AS s;
This following portion of the script will generate a command to restore mysql backup/dump into a specific database on the same or a different server
SET @restoreIntoDatabasename = @databaseName; -- the name of the new database you wish to restore into
SET @restoreFromFile = @filename; -- the full path of the filename you want to restore from
-- This query will generate the command to use to restore the generated backup into mysql
SELECT CONCAT_WS(' ', 'mysql -p -u root', @restoreIntoDatabasename, '<', @restoreFromFile);