14.16.8 从 INFORMATION_SCHEMA.FILES 检索 InnoDBtable 空间元数据
INFORMATION_SCHEMA.FILEStable 提供有关所有InnoDB
table 空间类型的元数据,包括file-per-table tablespaces,general tablespaces,system tablespace,临时 tabletable 空间和undo tablespaces(如果存在)。
本节提供特定于InnoDB
的用法示例。有关INFORMATION_SCHEMA.FILEStable 提供的数据的更多信息,请参见第 24.9 节“ INFORMATION_SCHEMA FILEStable”。
Note
INNODB_SYS_TABLESPACES和INNODB_SYS_DATAFILEStable 还提供有关InnoDB
table 空间的元数据,但数据仅限于每 table 文件和常规 table 空间。
该查询从INFORMATION_SCHEMA.FILEStable 的与InnoDB
table 空间相关的字段中检索有关InnoDB
系统 table 空间的元数据。与InnoDB
不相关的INFORMATION_SCHEMA.FILES字段始终返回 NULL,并从查询中排除。
mysql> SELECT FILE_ID, FILE_NAME, FILE_TYPE, TABLESPACE_NAME, FREE_EXTENTS,
TOTAL_EXTENTS, EXTENT_SIZE, INITIAL_SIZE, MAXIMUM_SIZE, AUTOEXTEND_SIZE, DATA_FREE, STATUS ENGINE
FROM INFORMATION_SCHEMA.FILES WHERE TABLESPACE_NAME LIKE 'innodb_system' \G
*************************** 1. row ***************************
FILE_ID: 0
FILE_NAME: ./ibdata1
FILE_TYPE: TABLESPACE
TABLESPACE_NAME: innodb_system
FREE_EXTENTS: 0
TOTAL_EXTENTS: 12
EXTENT_SIZE: 1048576
INITIAL_SIZE: 12582912
MAXIMUM_SIZE: NULL
AUTOEXTEND_SIZE: 67108864
DATA_FREE: 4194304
ENGINE: NORMAL
此查询检索每 tableInnoDB
文件和常规 table 空间的FILE_ID
(相当于空间 ID)和FILE_NAME
(包括路径信息)。每 table 文件和常规 table 空间的文件 extensions 是.ibd
。
mysql> SELECT FILE_ID, FILE_NAME FROM INFORMATION_SCHEMA.FILES
WHERE FILE_NAME LIKE '%.ibd%' ORDER BY FILE_ID;
+---------+---------------------------------------+
| FILE_ID | FILE_NAME |
+---------+---------------------------------------+
| 2 | ./mysql/plugin.ibd |
| 3 | ./mysql/servers.ibd |
| 4 | ./mysql/help_topic.ibd |
| 5 | ./mysql/help_category.ibd |
| 6 | ./mysql/help_relation.ibd |
| 7 | ./mysql/help_keyword.ibd |
| 8 | ./mysql/time_zone_name.ibd |
| 9 | ./mysql/time_zone.ibd |
| 10 | ./mysql/time_zone_transition.ibd |
| 11 | ./mysql/time_zone_transition_type.ibd |
| 12 | ./mysql/time_zone_leap_second.ibd |
| 13 | ./mysql/innodb_table_stats.ibd |
| 14 | ./mysql/innodb_index_stats.ibd |
| 15 | ./mysql/slave_relay_log_info.ibd |
| 16 | ./mysql/slave_master_info.ibd |
| 17 | ./mysql/slave_worker_info.ibd |
| 18 | ./mysql/gtid_executed.ibd |
| 19 | ./mysql/server_cost.ibd |
| 20 | ./mysql/engine_cost.ibd |
| 21 | ./sys/sys_config.ibd |
| 23 | ./test/t1.ibd |
| 26 | /home/user/test/test/t2.ibd |
+---------+---------------------------------------+
此查询检索InnoDB
个临时 table 空间的FILE_ID
和FILE_NAME
。临时 table 空间文件名以ibtmp
为前缀。
mysql> SELECT FILE_ID, FILE_NAME FROM INFORMATION_SCHEMA.FILES
WHERE FILE_NAME LIKE '%ibtmp%';
+---------+-----------+
| FILE_ID | FILE_NAME |
+---------+-----------+
| 22 | ./ibtmp1 |
+---------+-----------+
同样,InnoDB
undotable 空间文件名以undo
为前缀。如果配置了单独的撤消 table 空间,则以下查询将为InnoDB
撤消 table 空间返回FILE_ID
和FILE_NAME
。
mysql> SELECT FILE_ID, FILE_NAME FROM INFORMATION_SCHEMA.FILES
WHERE FILE_NAME LIKE '%undo%';