MySQL 中的 information_schema 数据库
1. 概述
information_schema 数据库跟 performance_schema 一样,都是 MySQL 自带的信息数据库。其中 performance_schema 用于性能分析,而 information_schema 用于存储数据库元数据(关于数据的数据),例如数据库名、表名、列的数据类型、访问权限等。
information_schema 中的表实际上是视图,而不是基本表,因此,文件系统上没有与之相关的文件。
mysql> use information_schema;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A
Database changed
mysql> show tables;
+---------------------------------------+
| Tables_in_information_schema |
+---------------------------------------+
| CHARACTER_SETS |
| COLLATIONS |
| COLLATION_CHARACTER_SET_APPLICABILITY |
| COLUMNS |
| COLUMN_PRIVILEGES |
| ENGINES |
| EVENTS |
| FILES |
| GLOBAL_STATUS |
| GLOBAL_VARIABLES |
| KEY_COLUMN_USAGE |
| OPTIMIZER_TRACE |
| PARAMETERS |
| PARTITIONS |
| PLUGINS |
| PROCESSLIST |
| PROFILING |
| REFERENTIAL_CONSTRAINTS |
| ROUTINES |
| SCHEMATA |
| SCHEMA_PRIVILEGES |
| SESSION_STATUS |
| SESSION_VARIABLES |
| STATISTICS |
| TABLES |
| TABLESPACES |
| TABLE_CONSTRAINTS |
| TABLE_PRIVILEGES |
| TRIGGERS |
| USER_PRIVILEGES |
| VIEWS |
| INNODB_LOCKS |
| INNODB_TRX |
| INNODB_SYS_DATAFILES |
| INNODB_FT_CONFIG |
| INNODB_SYS_VIRTUAL |
| INNODB_CMP |
| INNODB_FT_BEING_DELETED |
| INNODB_CMP_RESET |
| INNODB_CMP_PER_INDEX |
| INNODB_CMPMEM_RESET |
| INNODB_FT_DELETED |
| INNODB_BUFFER_PAGE_LRU |
| INNODB_LOCK_WAITS |
| INNODB_TEMP_TABLE_INFO |
| INNODB_SYS_INDEXES |
| INNODB_SYS_TABLES |
| INNODB_SYS_FIELDS |
| INNODB_CMP_PER_INDEX_RESET |
| INNODB_BUFFER_PAGE |
| INNODB_FT_DEFAULT_STOPWORD |
| INNODB_FT_INDEX_TABLE |
| INNODB_FT_INDEX_CACHE |
| INNODB_SYS_TABLESPACES |
| INNODB_METRICS |
| INNODB_SYS_FOREIGN_COLS |
| INNODB_CMPMEM |
| INNODB_BUFFER_POOL_STATS |
| INNODB_SYS_COLUMNS |
| INNODB_SYS_FOREIGN |
| INNODB_SYS_TABLESTATS |
+---------------------------------------+
61 rows in set (0.00 sec)
2. information_schema 库中常用的表
CHARACTER_SETS 表
可用字符集。SHOW CHARACTER SET;
命令从这个表获取结果。
mysql> SHOW CHARACTER SET;
mysql> SELECT * FROM CHARACTER_SETS;
SCHEMATA 表
当前mysql实例中所有数据库。SHOW DATABASES;
命令从这个表获取数据。
mysql> SELECT * FROM SCHEMATA;
mysql> show databases;
TABLES 表
存储数据库中的表信息(包括视图),包括表属于哪个数据库,表的类型、存储引擎、创建时间等信息。SHOW TABLES FROM XX;
命令从这个表获取结果。
mysql> SELECT * FROM TABLES;
mysql> SHOW TABLES FROM zentao;
COLUMNS 表
存储表中的列信息,包括表有多少列、每个列的类型等。SHOW COLUMNS FROM schemaname.tablename
命令从这个表获取结果。
mysql> SELECT * FROM COLUMNS LIMIT 2,5;
STATISTICS 表
表索引的信息。SHOW INDEX FROM schemaname.tablename;
命令从这个表获取结果。
mysql> SHOW INDEX FROM szhuizhong.users;
USER_PRIVILEGES 表
用户权限表。内容源自 mysql.user 授权表。是非标准表。
mysql> SELECT * FROM USER_PRIVILEGES;
SCHEMA_PRIVILEGES 表
方案权限表。给出了关于方案(数据库)权限的信息。内容来自 mysql.db 授权表。是非标准表。
mysql> SELECT * FROM SCHEMA_PRIVILEGES;
TABLE_PRIVILEGES 表
表权限表。给出了关于表权限的信息。内容源自 mysql.tables_priv 授权表。是非标准表。
mysql> SELECT * FROM TABLE_PRIVILEGES;
COLUMN_PRIVILEGES 表
列权限表。给出了关于列权限的信息。内容源自 mysql.columns_priv 授权表。是非标准表。
mysql> SELECT * FROM COLUMN_PRIVILEGES;
COLLATIONS 表
提供了关于各字符集的对照信息。SHOW COLLATION;
命令从这个表获取结果。
mysql> SELECT * FROM COLLATIONS;
COLLATION_CHARACTER_SET_APPLICABILITY 表
指明了可用于校对的字符集。相当于 SHOW COLLATION
命令结果的前两个字段。
mysql> SELECT * FROM COLLATION_CHARACTER_SET_APPLICABILITY;
TABLE_CONSTRAINTS 表
描述了存在约束的表。以及表的约束类型。
mysql> SELECT * FROM TABLE_CONSTRAINTS;
KEY_COLUMN_USAGE 表
描述了具有约束的键列。
mysql> SELECT * FROM KEY_COLUMN_USAGE;
ROUTINES 表
提供了关于存储子程序(存储程序和函数)的信息。此时,ROUTINES 表不包含自定义函数(UDF)。名为“mysql.proc name”的列指明了对应于 INFORMATION_SCHEMA.ROUTINES 表的 mysql.proc 列。
VIEWS 表
给出了关于数据库中的视图的信息。需要有 show views 权限,否则无法查看视图信息。
mysql> SELECT * FROM VIEWS LIMIT 1\G
*************************** 1. row ***************************
TABLE_CATALOG: def
TABLE_SCHEMA: sys
TABLE_NAME: host_summary
VIEW_DEFINITION: select if(isnull(`performance_schema`.`accounts`.`HOST`),'background',`performance_schema`.`accounts`.`HOST`) AS `host`,sum(`stmt`.`total`) AS `statements`,`sys`.`format_time`(sum(`stmt`.`total_latency`)) AS `statement_latency`,`sys`.`format_time`(ifnull((sum(`stmt`.`total_latency`) / nullif(sum(`stmt`.`total`),0)),0)) AS `statement_avg_latency`,sum(`stmt`.`full_scans`) AS `table_scans`,sum(`io`.`ios`) AS `file_ios`,`sys`.`format_time`(sum(`io`.`io_latency`)) AS `file_io_latency`,sum(`performance_schema`.`accounts`.`CURRENT_CONNECTIONS`) AS `current_connections`,sum(`performance_schema`.`accounts`.`TOTAL_CONNECTIONS`) AS `total_connections`,count(distinct `performance_schema`.`accounts`.`USER`) AS `unique_users`,`sys`.`format_bytes`(sum(`mem`.`current_allocated`)) AS `current_memory`,`sys`.`format_bytes`(sum(`mem`.`total_allocated`)) AS `total_memory_allocated` from (((`performance_schema`.`accounts` join `sys`.`x$host_summary_by_statement_latency` `stmt` on((`performance_schema`.`accounts`.`HOST` = `stmt`.`host`))) join `sys`.`x$host_summary_by_file_io` `io` on((`performance_schema`.`accounts`.`HOST` = `io`.`host`))) join `sys`.`x$memory_by_host_by_current_bytes` `mem` on((`performance_schema`.`accounts`.`HOST` = `mem`.`host`))) group by if(isnull(`performance_schema`.`accounts`.`HOST`),'background',`performance_schema`.`accounts`.`HOST`)
CHECK_OPTION: NONE
IS_UPDATABLE: NO
DEFINER: mysql.sys@localhost
SECURITY_TYPE: INVOKER
CHARACTER_SET_CLIENT: utf8
COLLATION_CONNECTION: utf8_general_ci
1 row in set (0.03 sec)
TRIGGERS 表
提供了关于触发程序的信息。必须有 super 权限才能查看该表。
mysql> SELECT * FROM TRIGGERS LIMIT 1\G
*************************** 1. row ***************************
TRIGGER_CATALOG: def
TRIGGER_SCHEMA: sys
TRIGGER_NAME: sys_config_insert_set_user
EVENT_MANIPULATION: INSERT
EVENT_OBJECT_CATALOG: def
EVENT_OBJECT_SCHEMA: sys
EVENT_OBJECT_TABLE: sys_config
ACTION_ORDER: 1
ACTION_CONDITION: NULL
ACTION_STATEMENT: BEGIN IF @sys.ignore_sys_config_triggers != true AND NEW.set_by IS NULL THEN SET NEW.set_by = USER(); END IF; END
ACTION_ORIENTATION: ROW
ACTION_TIMING: BEFORE
ACTION_REFERENCE_OLD_TABLE: NULL
ACTION_REFERENCE_NEW_TABLE: NULL
ACTION_REFERENCE_OLD_ROW: OLD
ACTION_REFERENCE_NEW_ROW: NEW
CREATED: 2017-05-27 11:18:43.60
SQL_MODE:
DEFINER: mysql.sys@localhost
CHARACTER_SET_CLIENT: utf8
COLLATION_CONNECTION: utf8_general_ci
DATABASE_COLLATION: utf8_general_ci
1 row in set (0.00 sec)
information_schema数据库表说明:
SCHEMATA表:提供了当前mysql实例中所有数据库的信息。是show databases的结果取之此表。
TABLES表:提供了关于数据库中的表的信息(包括视图)。详细表述了某个表属于哪个schema,表类型,表引擎,创建时间等信息。是show tables from schemaname的结果取之此表。
COLUMNS表:提供了表中的列信息。详细表述了某张表的所有列以及每个列的信息。是show columns from schemaname.tablename的结果取之此表。
STATISTICS表:提供了关于表索引的信息。是show index from schemaname.tablename的结果取之此表。
USER_PRIVILEGES(用户权限)表:给出了关于全程权限的信息。该信息源自mysql.user授权表。是非标准表。
SCHEMA_PRIVILEGES(方案权限)表:给出了关于方案(数据库)权限的信息。该信息来自mysql.db授权表。是非标准表。
TABLE_PRIVILEGES(表权限)表:给出了关于表权限的信息。该信息源自mysql.tables_priv授权表。是非标准表。
COLUMN_PRIVILEGES(列权限)表:给出了关于列权限的信息。该信息源自mysql.columns_priv授权表。是非标准表。
CHARACTER_SETS(字符集)表:提供了mysql实例可用字符集的信息。是SHOW CHARACTER SET结果集取之此表。
COLLATIONS表:提供了关于各字符集的对照信息。
COLLATION_CHARACTER_SET_APPLICABILITY表:指明了可用于校对的字符集。这些列等效于SHOW COLLATION的前两个显示字段。
TABLE_CONSTRAINTS表:描述了存在约束的表。以及表的约束类型。
KEY_COLUMN_USAGE表:描述了具有约束的键列。
ROUTINES表:提供了关于存储子程序(存储程序和函数)的信息。此时,ROUTINES表不包含自定义函数(UDF)。名为“mysql.proc name”的列指明了对应于INFORMATION_SCHEMA.ROUTINES表的mysql.proc表列。
VIEWS表:给出了关于数据库中的视图的信息。需要有show views权限,否则无法查看视图信息。
TRIGGERS表:提供了关于触发程序的信息。必须有super权限才能查看该表。
SCHEMATA表:提供了关于数据库的信息。
TABLES表:给出了关于数据库中的表的信息。
COLUMNS表:给出了表中的列信息。
STATISTICS表:给出了关于表索引的信息。
USER_PRIVILEGES表:给出了关于全程权限的信息。该信息源自mysql.user授权表。
SCHEMA_PRIVILEGES表:给出了关于方案(数据库)权限的信息。该信息来自mysql.db授权表。
TABLE_PRIVILEGES表:给出了关于表权限的信息。该信息源自mysql.tables_priv授权表。
COLUMN_PRIVILEGES表:给出了关于列权限的信息。该信息源自mysql.columns_priv授权表。
CHARACTER_SETS表:提供了关于可用字符集的信息。
COLLATIONS表:提供了关于各字符集的对照信息。
COLLATION_CHARACTER_SET_APPLICABILITY表:指明了可用于校对的字符集。
TABLE_CONSTRAINTS表:描述了存在约束的表。
KEY_COLUMN_USAGE表:描述了具有约束的键列。
ROUTINES表:提供了关于存储子程序(存储程序和函数)的信息。此时,ROUTINES表不包含自定义函数(UDF)。
VIEWS表:给出了关于数据库中的视图的信息。
TRIGGERS表:提供了关于触发程序的信息。
让普通用户登录phpmyadmin不显示information_schema如果不想在phpMyAdmin中显示的话只需要设置在config.inc.php(有的是config.default.php)中设置这样一句$cfg['Servers'][$i]['hide_db'] = 'information_schema';
十分钟了结MySQL information_schema
2.1 schemata表
schemata表提供了当前mysql实例中所有数据库的信息。show databases的结果取之此表。该表对应的列说明如下:
列名 | 中文解释 | 例子 |
catalog_name | ||
schema_name | 数据库名 | |
default_character_set_name | 数据库默认编码 | utf8 |
default_collation_name | utf8_general_ci | |
sql_path | null |
注释:SQL_PATH列的之总为NULL。
下述语句是等效的:
select schema_name as `database`
from information_schema.schemata
[where schema_name like 'db_ca_ods']
show databases
[like 'db_ca_ods']
2.2 tables表
tables表提供了关于数据库中的表的信息(包括视图)。详细表述了某个表属于哪个schema,表类型,表引擎,创建时间等信息。是show tables from db_ca_ods;【注db_ca_ods为数据库名】的结果取之此表。
列名 | 中文解释 | 例子/说明 |
table_catalog | NULL | |
table_schema | 数据库名称 | information_schema |
table_name | 表名 | tables表,属于information_schema数据库 |
table_type | 表类型 | 应是BASE TABLE(基本表)或VIEW(视图)。如果表是临时性的,TABLE_TYPE = TEMPORARY。(没有临时视图,因此,因此不存在歧义) |
engine | 表所用引擎 | InnoDB |
version |
Version |
|
row_format |
Row_format |
|
table_rows |
表中总行数 |
|
avg_row_length |
Avg_row_length |
|
data_length |
Data_length |
|
max_data_length |
Max_data_length |
|
index_length |
Index_length |
|
data_free |
Data_free |
|
auto_increment |
Auto_increment |
|
create_time |
Create_time |
|
update_time |
Update_time |
|
check_time |
Check_time |
|
table_collation |
Collation |
|
checksum |
Checksum |
|
create_options |
Create_options |
|
table_comment |
Comment |
表的说明,及create语句中comment的值 |
下述语句是等效的:
select table_name from information_schema.tables
[where table_schema = 'db_name']
[where|and table_name like 'wild']
show tables
[from db_name]
[like 'wild']
- 查看某个数据库表的记录数。
select table_schema,table_name,table_rows from tables where TABLE_SCHEMA = '数据库名称' order by table_rows desc;
- 查看数据库所占空间
select concat(round(sum(data_length/1024/1024),2),'MB') as data_length_MB, concat(round(sum(index_length/1024/1024),2),'MB') as index_length_MB from information_schema.tables where table_schema='数据库名';
- 查看某个表所占空间
select concat(truncate(sum(data_length)/1024/1024,2),'MB') as data_size, concat(truncate(sum(max_data_length)/1024/1024,2),'MB') as max_data_size, concat(truncate(sum(data_free)/1024/1024,2),'MB') as data_free, concat(truncate(sum(index_length)/1024/1024,2),'MB') as index_size from information_schema.tables where TABLE_NAME = '表名';
2.3 columns表
columns表提供了表中的列信息。详细表述了某张表的所有列以及每个列的信息。是show columns from schemaname(数据库名).tablename(表名)的结果取之此表。
2.4 statistics表
statistics表:提供了关于表索引的信息。是show index from schemaname.tablename的结果取之此表
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
查询数据库中所有的索引: SELECT CONCAT( 'ALTER TABLE `' ,TABLE_NAME, '` ' , 'ADD ' ,
IF(NON_UNIQUE = 1,
CASE UPPER (INDEX_TYPE)
WHEN 'FULLTEXT' THEN 'FULLTEXT INDEX'
WHEN 'SPATIAL' THEN 'SPATIAL INDEX'
ELSE CONCAT( 'INDEX `' ,
INDEX_NAME,
'` USING ' ,
INDEX_TYPE
)
END ,
IF( UPPER (INDEX_NAME) = 'PRIMARY' ,
CONCAT( 'PRIMARY KEY USING ' ,
INDEX_TYPE
),
CONCAT( 'UNIQUE INDEX `' ,
INDEX_NAME,
'` USING ' ,
INDEX_TYPE
) ) ), '(' , GROUP_CONCAT( DISTINCT CONCAT( '`' , COLUMN_NAME, '`' ) ORDER BY SEQ_IN_INDEX ASC SEPARATOR ', ' ), ');' ) AS 'Show_Add_Indexes'
FROM information_schema. STATISTICS
WHERE TABLE_SCHEMA = 'db_ods' -- 数据库名称
GROUP BY TABLE_NAME, INDEX_NAME
ORDER BY TABLE_NAME ASC , INDEX_NAME ASC ;
下述语句是等效的: select * from information_schema. statistics
where table_name = 'tbl_name'
[ and table_schema = 'db_name' ]
show index
from tbl_name
[ from db_name]
|
2.5 user_privileges表(用户权限表)
user_privileges(用户权限)表给出了关于全程权限的信息。该信息源自mysql.user授权表。是非标准表
列名 | 中文解释 | 例子/说明 |
grantee | 例如“user'@'host” | |
table_catalog | ||
privilege_type | 权限类型 | 例如:select、drop等 |
is_grantable | 是否授权,即是否拥有“将此权限赋予其他用户”的权限,对应mysql.user表中的grant_priv字段 | 例如:YES或NO |
实例如下:
2.6 schema_privileges表(方案/数据库权限表)
schema_privileges(方案权限)表给出了关于方案(数据库)权限的信息。该信息来自mysql.db授权表。是非标准表
列名 | 中文解释 | 例子/说明 |
grantee | 例“user'@'host” | |
table_catalog | ||
table_schema | 数据库名 | |
privilege_type | 权限类型 | |
is_grantable | 是否授权 | 例如:YES或NO |
2.7 table_privileges表(表权限表)
table_privileges(表权限)表给出了关于表权限的信息。该信息源自mysql.tables_priv授权表。是非标准表
2.8 column_privileges表(列权限表)
column_privileges(列权限)表给出了关于列权限的信息。该信息源自mysql.columns_priv授权表。是非标准表。
2.9 character_sets 字符集表
character_sets(字符集)表提供了mysql实例可用字符集的信息。是show character set结果集取之此表。
2.10 collations表
collations表提供了关于各字符集的对照信息。
2.11 collation_character_set_applicability表
collation_character_set_applicability表指明了可用于校对的字符集。这些列等效于show collation的前两个显示字段。
2.12 table_constraints表(存在约束的表的约束信息)
table_constraints表描述了存在约束的表。以及表的约束类型。
2.13 key_column_usage表(描述了具有约束的键列)
key_column_usage表描述了具有约束的键列。
2.14 routines表(mysql服务器中存储过程和函数信息)
routines表提供了关于存储子程序(存储程序和函数)的信息。此时,routines表不包含自定义函数(udf)。名为“mysql.proc name”的列指明了对应于information_schema.routines表的mysql.proc表列。
2.15 views表(视图表)
views表给出了关于数据库中的视图的信息。需要有show views权限,否则无法查看视图信息。
2.16 triggers表(触发器表)
triggers表提供了关于触发程序的信息。必须有super权限才能查看该表