查看原文
其他

初相识 | 全方位认识 information_schema

罗小波·沃趣科技 沃趣技术 2023-03-10


作者  罗小波·沃趣科技高级数据库技术专家

出品  沃趣科技


在"全方位认识 sys 系统库"系列文章中,已为大家详细介绍了 sys系统库,而sys 系统库中有一部分视图的数据来自information_schema。那么,什么是information_schema?information_schema组成对象又有哪些?本文将带领大家,启程去往information_schema学习之旅第一站。

PS:以下内容主要针对MySQL 5.7版本进行整理。


| 什么是information_schema

information_schema提供了对数据库元数据、统计信息、以及有关MySQL Server的信息访问(例如:数据库名或表名,字段的数据类型和访问权限等)。该库中保存的信息也可以称为MySQL的数据字典或系统目录。

  • 在每个MySQL 实例中都有一个独立的information_schema,用来存储MySQL实例中所有其他数据库的基本信息。information_schema数据库下包含多个只读表(非持久表),所以在磁盘中的数据目录下没有对应的关联文件,且不能对这些表设置触发器。虽然在查询时可以使用USE语句将默认数据库设置为information_schema,但该库下的所有表是只读的,不能执行INSERT、UPDATE、DELETE等数据变更操作。

针对information_schema下的表的查询操作可以替代一些show查询语句(例如:SHOW DATABASES,SHOW TABLES等),与使用show语句相比,通过查询information_schema下的表获取数据有以下优势:

  • 它符合"Codd法则",所有的访问都是基于表的访问完成的。

  • 可以使用SELECT语句的SQL语法,只需要学习你要查询的一些表名和列名的含义即可

  • 基于SQL语句的查询,对来自information_schema中的查询结果可以做过滤、排序、联结操作,查询的结果集格式对应用程序来说更友好

  • 这种技术实现与其他数据库系统中类似的实现更具互操作性。例如:Oracle数据库的用户熟悉查询Oracle数据字典中的表,那么在MySQL中查询数据字典的表也可以使用同样的方法来执行查询获取想要的数据

访问information_schema需要的权限

  • 所有用户都有访问information_schema下的表权限(但只能看到这些表中用户具有访问权限的对象相对应的数据行),但只能访问Server层的部分数据字典表,Server层中的部分数据字典表以及InnoDB层的数据字典表需要额外授权才能访问,如果用户权限不足,当查询Server层数据字典表时将不会返回任何数据,或者某个列没有权限访问时,该列返回NULL值。当查询InnoDB数据字典表时将直接拒绝访问(要访问这些表需要有process权限,注意不是select权限)

  • 从information_schema中查询相关数据需要的权限也适用于SHOW语句。无论使用哪种查询方式,都必须拥有某个对象的权限才能看到相关的数据。

PS:

  • 在MySQL 5.6版本中总共有59张表,其中10张MyISAM引擎临时表(数据字典表),49张Memory引擎临时表(保存统计信息和一些临时信息)。在MySQL 5.7版本中,该schema下总共有61张表,其中10个InnoDB存储引擎临时表(数据字典表),51个Memory引擎临时表。在MySQL 8.0中该schema下数据字典表(包含部分原memory引擎临时表)都迁移到了mysql schema下,且在mysql schema下这些数据字典表被隐藏,无法直接访问,需要通过information_schema下的同名表进行访问(统计信息表保留在information_schema下且仍然为Memory引擎)

  • 虽然直接通过查询information_schema中的表获取数据有众多优势,但是因为SHOW语法已经耳熟能详且被广泛使用,所以SHOW语句仍然是一个备选方法,且随着information_schema的实现,SHOW语句中的功能还有所增强(可以使用like或where子句进行过滤),例如:

# 语法
Syntax:
SHOW [GLOBAL | SESSIONVARIABLES
[LIKE 'pattern' | WHERE expr]

# 示例1
root@localhost : information_schema 12:20:31show variables like '%log_bin%';
+---------------------------------+----------------------------------------------------+
| Variable_name                  | Value                                              |
+---------------------------------+----------------------------------------------------+
| log_bin                        | ON                                                |
| log_bin_basename                | /home/mysql/data/mysqldata1/binlog/mysql-bin      |
| log_bin_index                  | /home/mysql/data/mysqldata1/binlog/mysql-bin.index |
| log_bin_trust_function_creators | ON                                                |
| log_bin_use_v1_row_events      | OFF                                                |
| sql_log_bin                    | ON                                                |
+---------------------------------+----------------------------------------------------+
6 rows in set (0.00 sec)

# 实例2
root@localhost : information_schema 12:21:41show variables where Variable_name like 'log_bin%' and Value='ON';
+---------------------------------+-------+
| Variable_name                  | Value |
+---------------------------------+-------+
| log_bin                        | ON    |
| log_bin_trust_function_creators | ON    |
+---------------------------------+-------+
2 rows in set (0.00 sec)

# 注意,like与where子句可单独使用,但要同时使用where与like子句时,like子句必须在where之后


| information_schema 组成对象

information_schema下的所有表都是使用的Memory和InnoDB存储引擎,且都是临时表,不是持久表,在数据库重启之后这些数据会丢失,在MySQL 的4个系统库中,也是唯一一个在文件系统上没有对应库表的目录和文件的系统库。

下面我们按照这些表的各自用途的相似度,我们把information_schema下的表做了如下归类,本期我们先大致了解下information_schema系统库中都有哪些表,这些表大致都有什么用途。

1. Server层统计信息字典表

COLUMNS:

  • 提供查询表中的列(字段)信息

  • 该表为InnoDB 存储引擎的临时表

KEY_COLUMN_USAGE:

  • 提供查询哪些索引列存在约束条件

  • 该表中的信息包含主键、唯一索引、外键等约束的信息,例如:所在库表列名,引用的库表列名等。表中的信息与TABLE_CONSTRAINTS表中记录的信息有些类似,但TABLE_CONSTRAINTS表中没有记录约束引用的库表列信息。但是却记录了TABLE_CONSTRAINTS表中所没有的约束类型信息

  • 该表为Memory引擎临时表

REFERENTIAL_CONSTRAINTS:

  • 提供查询关于外键约束的一些信息

  • 该表为Memory引擎临时表

STATISTICS:

  • 提供查询关于索引的一些统计信息,一个索引对应一行记录

  • 该表为Memory引擎临时表

TABLE_CONSTRAINTS:

  • 提供查询表相关的约束信息

  • 该表为Memory引擎临时表

FILES:

  • 提供查询MySQL的数据表空间文件相关的信息,包含InnoDB存储引擎和NDB存储引擎相关的数据文件信息,由于NDB存储引擎在国内较少使用,我们大多数场景(95%以上场景InnoDB存储引擎都满可以使用)都是使用InnoDB存储引擎

  • 该表为Memory存储引擎表

ENGINES:

  • 提供查询MySQL Server支持的引擎相关的信息

  • 该表为Memory引擎临时表

TABLESPACES:

  • 提供查询关于活跃表空间的相关信息(主要记录的是NDB存储引擎表空间信息)

  • 注意:该表不提供有关InnoDB存储引擎的表空间的信息。 对于InnoDB表空间元数据信息,请查询INNODB_SYS_TABLESPACES和INNODB_SYS_DATAFILES表。另外,从MySQL 5.7.8开始,INFORMATION_SCHEMA.FILES表也提供查询InnoDB表空间的元数据信息

  • 该表为Memory引擎临时表。

SCHEMATA:

  • 提供查询MySQL Server中的数据库列表信息,一个schema就代表一个database

  • 该表为Memory引擎临时表

2. Server层表级别对象字典表

VIEWS:

  • 提供查询数据库中的视图相关的信息,查询该表的帐号需要拥有show view权限

  • 该表为InnoDB引擎临时表

TRIGGERS:

  • 提供查询关于某个数据库下的触发器相关的信息,要查询某个表的触发器,查询的账户必须要有trigger权限

  • 该表为InnoDB引擎临时表

TABLES:

  • 提供查询数据库内的表相关的基本信息

  • 该表为Memory引擎临时表

ROUTINES:

  • 提供查询关于存储过程和存储函数的信息(不包括用户自定义函数UDF),该表中的信息与“mysql.proc”中记录的信息相对应(如果该表中有值的话)

  • 该表为InnoDB引擎临时表

PARTITIONS:

  • 提供查询关于分区表的信息

  • 该表为InnoDB引擎临时表

EVENTS:

  • 提供查询计划任务事件相关的信息

  • 该表是InnoDB引擎临时表

PARAMETERS:

  • 提供有关存储过程和函数的参数信息,以及有关存储函数的返回值的信息。 这些参数信息与mysql.proc表中的param_list列记录的内容类似

  • 该表为InnoDB引擎临时表

3. Server 层混杂信息字典表

GLOBAL_STATUS、GLOBAL_VARIABLES、SESSION_STATUS、SESSION_VARIABLES:

  • 提供查询全局、会话级别的的状态变量与系统变量信息,这些表为Memory引擎临时表

OPTIMIZER_TRACE:

  • 提供优化程序跟踪功能产生的信息。

  • 跟踪功能默认关闭,使用optimizer_trace系统变量启用跟踪功能。如果开启该功能,则每个会话只能跟踪他自己执行的语句,不能看到其他会话执行的语句,且每个会话只能记录最后一个跟踪的SQL语句

  • 该表为InnoDB引擎临时表

PLUGINS:

  • 提供查询关于MySQL Server中支持哪些插件的信息

  • 该表为InnoDB引擎临时表

PROCESSLIST:

  • 提供查询一些关于线程运行过程中的状态信息

  • 该表为InnoDB引擎临时表

PROFILING:

  • 提供查询关于语句性能分析的信息。其记录内容对应于SHOW PROFILES和SHOW PROFILE语句产生的信息。该表需要在会话变量 profiling=1时才会记录语句性能分析信息,否则该表不记录。

  • 注意:从MySQL 5.7.2开始,此表不再推荐使用,在未来的MySQL版本中删除。改用Performance Schema;代替

  • 该表为Memory引擎临时表

CHARACTER_SETS:

  • 提供查询MySQL Server支持的可用字符集有哪些

  • 该表为Memory引擎临时表

COLLATIONS:

  • 提供查询MySQL Server支持的可用校对规则有哪些

  • 该表为Memory引擎临时表

COLLATION_CHARACTER_SET_APPLICABILITY:

  • 提供查询MySQL Server中哪种字符集适用于什么校对规则。查询结果集相当于从SHOW COLLATION获得的结果集中的前两个字段值。该表目前并没有发现有太大作用,为Memory引擎临时表

COLUMN_PRIVILEGES:

  • 提供查询关于列(字段)的权限信息,表中的内容来自mysql.column_priv列权限表(需要针对一个表的列单独授权之后才会有内容)

  • 该表为Memory引擎临时表

SCHEMA_PRIVILEGES:

  • 提供查询关于库级别的权限信息,每种类型的库级别权限记录一行信息,该表中的信息来自mysql.db表

  • 该表为Memory引擎临时表

TABLE_PRIVILEGES:

  • 提供查询关于表级别权限信息,该表中的内容来自mysql.tables_priv

  • 该表为Memory引擎临时表

USER_PRIVILEGES:

  • 提供查询全局权限的信息,该表中的信息来自mysql.user表

  • 该表为Memory引擎临时表

4. InnoDB 层系统字典表

INNODB_SYS_DATAFILES:

  • 提供查询InnoDB file-per-table和常规表空间数据文件的路径信息,等同于InnoDB数据字典中SYS_DATAFILES表中的信息

  • 该表中的信息包含InnoDB所有表空间类型的元数据,包括独立表空间、常规表空间、系统表空间、临时表空间和undo表空间(如果开启了独立表空间的话)

  • 该表为memory引擎临时表,查询该表的用户需要有process权限。

INNODB_SYS_VIRTUAL:

  • 提供查询有关InnoDB虚拟生成列和与之关联的列的元数据信息,等同于InnoDB数据字典内部SYS_VIRTUAL表中的信息。INNODB_SYS_VIRTUAL表中展示的行信息是虚拟生成列相关联列的每个列的信息。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_INDEXES:

  • 提供查询有关InnoDB索引的元数据信息,等同于InnoDB数据字典内部SYS_INDEXES表中的信息

  • 该表为memory引擎临时表,查询该表的用户需要具有process权限

INNODB_SYS_TABLES:

  • 提供查询有关InnoDB表的元数据,等同于InnoDB数据字典内部SYS_TABLES表的信息。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_FIELDS:

  • 提供查询有关InnoDB索引键列(字段)的元数据信息,等同于InnoDB数据字典内部SYS_FIELDS表的信息

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_TABLESPACES:

  • 提供查询有关InnoDB独立表空间和普通表空间的元数据信息(也包含了全文索引表空间),等同于InnoDB数据字典内部SYS_TABLESPACES表中的信息

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_FOREIGN_COLS:

  • 提供查询有关InnoDB外键列的状态信息,等同于InnoDB数据字典内部SYS_FOREIGN_COLS表的信息

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_COLUMNS:

  • 提供查询有关InnoDB表列的元数据信息,等同于InnoDB数据字典内部SYS_COLUMNS表的信息

  • 该表为memory引擎临时表,查询该表的用户需要具有process权限

INNODB_SYS_FOREIGN:

  • 提供查询有关InnoDB外键的元数据信息,等同于InnoDB数据字典内部SYS_FOREIGN表的信息

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_SYS_TABLESTATS:

  • 提供查询有关InnoDB表的较低级别的状态信息视图。 MySQL优化器会使用这些统计信息数据来计算并确定在查询InnoDB表时要使用哪个索引。这些信息保存在内存中的数据结构中,与存储在磁盘上的数据无对应关系。InnoDB内部也无对应的系统表。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

5. InnoDB 层锁、事务、统计信息字典表

INNODB_LOCKS:

  • 提供查询innodb引擎事务中正在请求的且并未获得的且同时阻塞了其他事务的锁信息(即没有发生不同事务之间的锁等待的锁信息,在这里是查看不到的,例如,只有一个事务时,该事务所加的锁信息无法查看到)。该表中的内容可以用于诊断高并发下的锁争用信息。

  • 该表为memory引擎临时表,访问该表需要拥有具有process权限

INNODB_TRX:

  • 提供查询当前在InnoDB引擎中执行的每个事务(不包括只读事务)的信息,包括事务是否正在等待锁、事务什么时间点开始、以及事务正在执行的SQL语句文本信息等(如果有SQL的话)。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_BUFFER_PAGE_LRU:

  • 提供查询缓冲池中的页面信息,与INNODB_BUFFER_PAGE表不同,INNODB_BUFFER_PAGE_LRU表保存有关innodb buffer pool中的页如何进入LRU链表以及在buffer pool不够用时确定需要从缓冲池中逐出哪些页

  • 该表为Memory引擎临时表

INNODB_LOCK_WAITS:

  • 提供查询关于每个被阻塞的InnoDB事务的锁等待记录,包括发生锁等带事务所请求的锁和阻止该锁请求被授予的锁

  • 该表为memory引擎表,访问该表用户需要有process权限

INNODB_TEMP_TABLE_INFO:

  • 提供查询有关在InnoDB实例中当前处于活动状态的用户(已建立连接的用户,断开的用户连接对应的临时表会被自动删除)创建的InnoDB临时表的信息。 它不提供查询优化器使用的内部InnoDB临时表的信息查询。INNODB_TEMP_TABLE_INFO表在首次查询时创建。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_BUFFER_PAGE:

  • 提供查询关于buffer pool中的页相关的信息

  • 查询该表需要用户具有PROCESS权限,该表为Memory引擎临时表

INNODB_METRICS:

  • 提供查询InnoDB更为详细细致的性能信息,是对InnoDB的PERFORMANCE_SCHEMA的补充。通过对该表的查询,可用于检查innodb的整体健康状况。也可用于诊断性能瓶颈、资源短缺和应用程序的问题等。

  • 该表为memory引擎临时表,查询该表的用户需要有process权限

INNODB_BUFFER_POOL_STATS:

  • 提供查询一些Innodb buffer pool中的状态信息,该表中记录的信息与SHOW ENGINE INNODB STATUS输出的信息类似相同,另外,innodb buffer pool的一些状态变量也提供了部分相同的值

  • 查看该表需要有process权限,该表为Memory引擎临时表

6. InnoDB 层全文索引字典表

INNODB_FT_CONFIG:

  • 提供查询有关InnoDB表的FULLTEXT索引和关联的元数据信息。查询此表之前,需要先设置innodb_ft_aux_table='db_name/tb_name',db_name/tb_name为包含全文索引的表名和库名。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

INNODB_FT_BEING_DELETED:

  • 该表仅在OPTIMIZE TABLE语句执行维护操作期间作为INNODB_FT_DELETED表的快照数据存放使用。运行OPTIMIZE TABLE语句时,会先清空INNODB_FT_BEING_DELETED表中的数据,保存INNODB_FT_DELETED表中的快照数据到INNODB_FT_BEING_DELETED表,并从INNODB_FT_DELETED表中删除DOC_ID。由于INNODB_FT_BEING_DELETED表中的内容通常生命周期较短,因此该表中的数据对于监控或者调试来说用处并不大。

  • 表中默认不记录数据,需要设置系统配置参数innodb_ft_aux_table=string(string表示db_name.tb_name字符串),并创建好全文索引,设置好停用词等。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

INNODB_FT_DELETED:

  • 提供查询从InnoDB表的FULLTEXT索引中删除的行信息。它的存在是为了避免在InnoDB FULLTEXT索引的DML操作期间进行昂贵的索引重组操作,新删除的全文索引中单词的信息将单独存储在该表中,在执行文本搜索时从中过滤出搜索结果,该表中的信息仅在执行OPTIMIZE TABLE语句时清空。

  • 该表中的信息默认不记录,需要使用innodb_ft_aux_table选项(该选项默认值为空串)指定需要记录哪个innodb引擎表的信息,例如:test/test。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

INNODB_FT_DEFAULT_STOPWORD:

  • 该表为默认的全文索引停用词表,提供查询停用词列表值。启用停用词表需要开启参数innodb_ft_enable_stopword=ON,该参数默认为ON,启用停用词功能之后,如果innodb_ft_user_stopword_table选项(针对指定的innodb引擎表中的全文索引生效)自定义了停用词库表名称值,则停用词功能使用innodb_ft_user_stopword_table选项指定的停用词表,如果innodb_ft_user_stopword_table选项未指定,而innodb_ft_server_stopword_table选项(针对所有的innodb引擎表中的全文索引生效)自定义了停用词库表名称值,则同停用词功能使用innodb_ft_server_stopword_table选项指定的停用词表,如果innodb_ft_server_stopword_table选项也未指定,则使用默认的停用词表,即INNODB_FT_DEFAULT_STOPWORD表。

  • 查询该表需要账户有PROCESS权限,该表为Memory引擎临时表

INNODB_FT_INDEX_TABLE:

  • 提供查询关于innodb表全文索引中用于反向文本查找的倒排索引的分词信息。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

INNODB_FT_INDEX_CACHE:

  • 提供查询包含FULLTEXT索引的innodb存储引擎表中新插入行的全文索引标记信息。它存在的目的是为了避免在DML操作期间进行昂贵的索引重组,新插入的全文索引的单词的信息被单独存储在该表中,直到对表执行OPTIMIZE TABLE语句时、或者关闭服务器时、或者当高速缓存中存放的信息大小超过了innodb_ft_cache_size或innodb_ft_total_cache_size系统配置参数指定的大小才会执行清理。默认不记录数据,需要使用innodb_ft_aux_table系统配置参数指定需要记录哪个表中的新插入行的全文索引数据。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

7. InnoDB 层压缩相关字典表

INNODB_CMP和INNODB_CMP_RESET:

  • 这两个表中的数据包含了与压缩的InnoDB表页有关的操作的状态信息。表中记录的数据为测量数据库中的InnoDb表压缩的有效性提供参考。

  • 查询表的用户必须具有PROCESS权限,该表为Memory引擎临时表

INNODB_CMP_PER_INDEX和INNODB_CMP_PER_INDEX_RESET:

  • 这两个表中记录着InnoDB压缩表数据和索引相关的操作状态信息,对数据库、表、索引的每个组合使用不同的统计信息,以便为评估特定表的压缩性能和实用性提供参考数据。

  • 对于InnoDB压缩表,会对表中的数据和所有二级索引都进行压缩。此时表中的数据被视为另一个索引(包含所有数据列的聚集索引)。

  • 注意:由于为每个索引收集单独的度量值会导致性能大幅度降低,因此默认情况下不收集INNODB_CMP_PER_INDEX和INNODB_CMP_PER_INDEX_RESET表统计信息。如果确有需要,启用系统配置参数innodb_cmp_per_index_enabled即可(该配置参数为动态变量,默认为OFF)。

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表

INNODB_CMPMEM和INNODB_CMPMEM_RESET:

  • 这两个表中记录着InnoDB缓冲池中压缩页上的状态信息,为测量数据库中InnoDB表压缩的有效性提供参考

  • 查询该表的账户需要有PROCESS权限,该表为Memory引擎临时表


本期内容就介绍到这里,本期内容参考链接如下:

  • https://dev.mysql.com/doc/refman/5.7/en/information-schema.html



| 作者简介

罗小波·沃趣科技高级数据库技术专家

IT从业多年,历任运维工程师,高级运维工程师,运维经理,数据库工程师,曾参与版本发布系统,轻量级监控系统,运维管理平台,数据库管理平台的设计与编写,熟悉MySQL的体系结构时,InnoDB存储引擎,喜好专研开源技术,追求完美。


点击查看招聘信息


相关链接

Kubernetes何时才会消于无形却又无处不在?

沃趣微讲堂 | Oracle集群技术(四):集群初始化资源层

复制错误案例分享(二)

SQL优化案例-使用with as优化Subquery Unnesting(七)

MySQL分析函数实现

Pod挂载Volume失败问题分析

18C新特性之PDB snapshot Carousel,够用吗?


更多干货,欢迎来撩~

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存