我的MySQL数据库包含几个使用不同存储引擎的表 (特别是myisam和innodb)。我怎么知道是哪几张桌子呢 使用哪个引擎?


当前回答

转到information_schema数据库,你会发现'tables'表,然后选择它;

Mysql >使用information_schema; Mysql> select table_name, from tables;

其他回答

SHOW CREATE TABLE <tablename>;

可解析性较差,但可读性比SHOW TABLE STATUS强。

SHOW TABLE STATUS WHERE Name = 'xxx'

这将为您提供一个Engine列(以及其他内容),这就是您想要的。

如果您正在使用MySQL Workbench,右键单击一个表并选择alter table。

在这个窗口中,您可以看到您的表Engine,也可以更改它。

除了前面的例子外,你还可以从information_schema db中通过标准查询得到如下信息:

use information_schema;

select NAME from INNODB_TABLES where NAME like "db_name%";
mysqlshow -i <database_name>

将显示特定数据库的所有表的信息。

mysqlshow -i <database_name> <table_name> 

只对一个特定的表这样做。