微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

怎样批量修改mysql数据库myisam引擎为innodb

《怎样批量修改MysqL数据库myisam引擎为innodb》要点:
本文介绍了怎样批量修改MysqL数据库myisam引擎为innodb,希望对您有用。如果有疑问,可以联系我们。

今天升级MysqL 5.7,准备把原来数据库MysqL数据库引擎从5.6升级为5.7,因为表格众多,一个修改很累,所以要有批量修改方法

一个修改方法是:

MysqL> alter table vePHP engine=innodb;
Query OK, 16777216 rows affected (2 min 39.80 sec)
Records: 16777216  Duplicates: 0  Warnings: 0

那么批量修改方法就是批量执行ALTER TABLE即可。

我们生成这样的语句即可。执行:

SELECT CONCAT('ALTER TABLE ',table_name,' ENGINE=InnoDB;') 
FROM information_schema.tablesWHERE table_schema=vePHP数据库 AND ENGINE=MyISAM;

生成

ALTER TABLE xxxxx ENGINE=InnoDB;               
ALTER TABLE zzzzzzzzz ENGINE=InnoDB;          
ALTER TABLE vvvvvvvvvv ENGINE=InnoDB;         
ALTER TABLE eeeeeee ENGINE=InnoDB;            
ALTER TABLE ppppppp ENGINE=InnoDB;
....

如图:

怎样批量修改mysql数据库myisam引擎为innodb

把这些表格数据导出,在sql中执行即可。

也可以放在PHP中执行,如下:

$s = ALTER TABLE aaaa ENGINE=InnoDB;          
ALTER TABLE bbbbb ENGINE=InnoDB;              
ALTER TABLE ccccc ENGINE=InnoDB;              
ALTER TABLE ddddd ENGINE=InnoDB;;
$s = array_filter (explode (\n,$s));
foreach ($s as $sql)
{
       $db->query($sql);  //这里是VEPHP框架查询,需要改成你的SQL查询命令
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐