怎样批量修改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查询命令
}

相关文章

MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导...
在MySQL中,InnoDB引擎通过Next-Key Locking技术来解决幻读问...
在数据库事务管理中,Undo Log 和 Redo Log 是两种关键日志,...
case when概述 sql语句中的case语句与高级语言中的switch语句...
其实很简单,只是为了忘记,做个记录,用的时候方便。 不管是...
1.进入服务,找到mysql服务,在属性里找到mysql的安装路径 2...