我的 MySQL 数据库包含几个使用不同存储引擎(特别是 myisam 和 innodb)的表。如何找出哪些表正在使用哪个引擎?
14 回答
SHOW TABLE STATUS WHERE Name = 'xxx'
这将为您(除其他外)提供一个Engine
列,这就是您想要的。
要显示数据库中所有表及其引擎的列表,请使用以下 SQL 查询:
SELECT TABLE_NAME,
ENGINE
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = 'dbname';
替换dbname
为您的数据库名称。
SHOW CREATE TABLE <tablename>;
比 . 更难解析但更易读SHOW TABLE STATUS
。
要不就
show table status;
只是这将列出您数据库中的所有表。
对 Jocker 的回应稍作调整(我会发表评论,但我还没有足够的业力):
SELECT TABLE_NAME, ENGINE
FROM information_schema.TABLES
WHERE TABLE_SCHEMA = 'database' AND ENGINE IS NOT NULL;
这从列表中排除了没有引擎的 MySQL 视图。
SHOW CREATE TABLE <tablename>\G
与输出相比,它的格式会更好
SHOW CREATE TABLE <tablename>;
该\G
技巧对于许多其他查询/命令也很有用。
mysqlshow -i <database_name>
将显示特定数据库的所有表的信息。
mysqlshow -i <database_name> <table_name>
将只针对特定表执行此操作。
如果您使用的是MySQL Workbench,请右键单击表并选择alter table
.
在该窗口中,您可以看到您的表引擎并对其进行更改。
还有另一种方式,也许是获得单个或匹配的一组表状态的最短时间:
SHOW TABLE STATUS LIKE 'table';
然后,您可以使用 LIKE 运算符,例如:
SHOW TABLE STATUS LIKE 'field_data_%';
如果你是 linux 用户:
要显示 mysql 服务器上所有数据库的所有表的引擎,不包括表information_schema
, mysql
, performance_schema
:
less < <({ for i in $(mysql -e "show databases;" | cat | grep -v -e Database-e information_schema -e mysql -e performance_schema); do echo "--------------------$i--------------------"; mysql -e "use $i; show table status;"; done } | column -t)
至少,如果您使用的是 linux,您可能会喜欢这个。
将打开 中所有表格的所有信息less
,按下-S
可截断过长的行。
示例输出:
--------------------information_schema--------------------
Name Engine Version Row_format Rows Avg_row_length Data_length Max_data_length Index_length Data_free Auto_increment Create_time Update_time Check_time C
CHARACTER_SETS MEMORY 10 Fixed NULL 384 0 16434816 0 0 NULL 2015-07-13 15:48:45 NULL N
COLLATIONS MEMORY 10 Fixed NULL 231 0 16704765 0 0 NULL 2015-07-13 15:48:45 NULL N
COLLATION_CHARACTER_SET_APPLICABILITY MEMORY 10 Fixed NULL 195 0 16357770 0 0 NULL 2015-07-13 15:48:45 NULL N
COLUMNS MyISAM 10 Dynamic NULL 0 0 281474976710655 1024 0 NULL 2015-07-13 15:48:45 2015-07-13 1
COLUMN_PRIVILEGES MEMORY 10 Fixed NULL 2565 0 16757145 0 0 NULL 2015-07-13 15:48:45 NULL N
ENGINES MEMORY 10 Fixed NULL 490 0 16574250 0 0 NULL 2015-07-13 15:48:45 NULL N
EVENTS MyISAM 10 Dynamic NULL 0 0 281474976710655 1024 0 NULL 2015-07-13 15:48:45 2015-07-13 1
FILES MEMORY 10 Fixed NULL 2677 0 16758020 0 0 NULL 2015-07-13 15:48:45 NULL N
GLOBAL_STATUS MEMORY 10 Fixed NULL 3268 0 16755036 0 0 NULL 2015-07-13 15:48:45 NULL N
GLOBAL_VARIABLES MEMORY 10 Fixed NULL 3268 0 16755036 0 0 NULL 2015-07-13 15:48:45 NULL N
KEY_COLUMN_USAGE MEMORY 10 Fixed NULL 4637 0 16762755 0
.
.
.
转到 information_schema 数据库,您会找到“tables”表,然后选择它;
mysql>使用信息架构;mysql> select table_name,engine from tables;
如果您是GUI人并且只想在PhpMyAdmin中找到它,那么选择您选择的表并转到Operations
选项卡 >> Table options
>> Storage Engine
。您甚至可以使用下拉选项列表从那里更改它。
PS:本指南基于 PhpMyAdmin 4.8 版。不能保证非常旧版本的路径相同。
除了前面条目中显示的示例外,您还可以使用标准查询从 information_schema db 中获取,如下所示:
use information_schema;
select NAME from INNODB_TABLES where NAME like "db_name%";