MySQL information_schema 系统库介绍

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: 当我们安装好 MySQL 数据库后,会发现数据库实例自带有 information_schema 系统库,你是否有去关注过这个系统库呢?是否有查询过此库中的表数据呢?又是否清楚此库存在的具体作用呢?带着这些疑问,我们一起来看本篇文章。

1. information_schema 简介


information_schema 顾名思义就是一个信息库,是用来存储数据库的元数据(比如数据库,表的名称,列的数据类型或者访问权限等),在每个 MySQL 实例中,information_schema 保存了它维护的所有数据库的信息,这个库中包含了很多只读的表(它们实际上可看作为视图,因此并没有与之关联的文件,你也无法为它们创建触发器)。


我们来具体看下 information_schema 下的表,不同版本的数据库稍有区别,以 5.7.23 版本为例,打开 information_schema 库,我们发现共有 61 个表。


image.png

image.png


可以很明显看出,information_schema 下的表大部分是 MEMORY 存储引擎,有个别是 InnoDB 存储引擎,再仔细看这些表的创建语句,发现这些表都是临时表。下面展示部分表的作用:


  • CHARACTER_SETS:可用的字符集信息表。
  • COLLATIONS:字符集排序规则信息表。
  • COLUMNS:每个表中的列的信息。
  • ENGINES:存储引擎的信息,可以用于检查引擎是否支持。
  • FILES:表空间数据存储文件的信息。
  • GLOBAL_STATUS:全局状态变量值。
  • GLOBAL_VARIABLES:全局系统变量值。
  • INNODB_BUFFER_PAGE:InnoDB 缓冲池中页的信息。
  • INNODB_BUFFER_POOL_STATS:InnoDB 缓冲池统计信息。
  • INNODB_LOCK_WAITS:InnoDB 事务锁等待信息
  • INNODB_LOCKS:包含了事务请求但是未获得的锁或者阻塞其它事务的锁的信息。
  • INNODB_TRX:所有当前正在执行的事务的信息。
  • PARTITIONS:记录表分区信息。
  • PLUGINS:服务器安装的插件信息。
  • PROCESSLIST:记录正在运行的线程的各种信息。
  • ROUTINES:存储过程及函数信息。
  • SCHEMATA:数据库的信息。
  • STATISTICS:表索引信息。
  • TABLES:表的信息。
  • TRIGGERS:触发器信息。
  • VIEWS:数据库视图信息。


2. information_schema 相关查询


其实,在使用数据库的过程中,你经常与 information_schema 打交道,当我们想查询 MySQL 中各种对象的信息时,基本上都是从 information_schema 库中查询得到的。一些常见的 show 语句背后的逻辑也是查询 information_schema 库,例如:show tables 其实查的就是 information_schema.TABLES 表;show databases、show processlist 等语句查询的都是 information_schema 库中的相关表。


我们想了解数据库中的各种信息时,都可以查询 information_schema 库,下面分享几条笔者积累的相关查询语句,来看下吧。

# 查看某个库中的表信息
SELECT
    table_name,
    table_type,
  ENGINE 
FROM
    information_schema.TABLES 
WHERE
    table_schema = 'db5' 
ORDER BY
    table_name
# 查看整个实例占用空间
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;
# 查看各个库占用空间
SELECT
    TABLE_SCHEMA,
    concat( TRUNCATE ( sum( data_length )/ 1024 / 1024, 2 ), ' MB' ) AS data_size,
    concat( TRUNCATE ( sum( index_length )/ 1024 / 1024, 2 ), 'MB' ) AS index_size 
FROM
    information_schema.TABLES 
GROUP BY
    TABLE_SCHEMA 
ORDER BY
    data_length 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 = 'test' 
    AND table_name = 'test_tb'
# 查看所有线程信息
SELECT
    * 
FROM
    information_schema.PROCESSLIST
# 查看非睡眠线程信息
SELECT
    * 
FROM
    information_schema.PROCESSLIST 
WHERE
    command != 'sleep'
# 查看某个用户发起的线程信息
SELECT
    * 
FROM
    information_schema.PROCESSLIST 
WHERE
    USER = 'testuser'
# 查看某个字符集支持的所有排序规则
SELECT
    COLLATION_NAME,
    CHARACTER_SET_NAME,
    IS_DEFAULT
FROM
    `information_schema`.`COLLATIONS` 
WHERE
    `CHARACTER_SET_NAME` = 'utf8' 
# 查看某个表的分区信息(如果有)
SELECT
    TABLE_SCHEMA,
    TABLE_NAME,
    PARTITION_NAME 
FROM
    `information_schema`.`PARTITIONS` 
WHERE
    `TABLE_SCHEMA` = 'test' 
    AND `TABLE_NAME` = 'tbname'
# 查看某个表的索引信息
SELECT
    * 
FROM
    `information_schema`.`STATISTICS` 
WHERE
    `TABLE_SCHEMA` = 'test' 
    AND `TABLE_NAME` = 'tbname' 
# 查看 innodb 事务相关信息
SELECT
    * 
FROM
    information_schema.INNODB_TRX


总结:


本文主要介绍 information_schema 系统库相关内容,我们想知道的数据库元数据信息基本上都可以查到,熟悉 information_schema 库有助于我们对数据库更加了解,有兴趣的同学可以看下 information_schema 下的表,一定会有收获的。

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
23天前
|
关系型数据库 MySQL 数据库
docker MySQL删除数据库时的错误(errno: 39)
docker MySQL删除数据库时的错误(errno: 39)
96 0
|
15天前
|
关系型数据库 MySQL Apache
实时计算 Flink版操作报错之mysql整库同步到doris连接器报错,如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
|
15天前
|
存储 关系型数据库 MySQL
【MySQL】操作库 —— 库的操作 -- 详解
【MySQL】操作库 —— 库的操作 -- 详解
|
23天前
|
Java 关系型数据库 MySQL
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口(下)
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口
139 0
|
23天前
|
Java 关系型数据库 MySQL
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口(上)
【MySQL × SpringBoot 突发奇想】全面实现流程 · xlsx文件,Excel表格导入数据库的接口
74 0
|
2天前
|
SQL 关系型数据库 MySQL
mysql从库SHOW SLAVE STATUS字段详解
mysql从库SHOW SLAVE STATUS字段详解
8 0
|
3天前
|
关系型数据库 MySQL 数据库连接
【MySQL】库的操作
【MySQL】库的操作
|
15天前
|
存储 关系型数据库 MySQL
【MySQL】操作库 —— 表的操作 -- 详解
【MySQL】操作库 —— 表的操作 -- 详解
|
17天前
|
关系型数据库 MySQL Linux
在Linux系统中安装MySQL数据库
在Linux系统中安装MySQL数据库
81 3
|
21天前
|
JavaScript Java 关系型数据库
基于springboot+vue+Mysql的交流互动系统
简化操作,便于维护和使用。
29 2