创意电子

标题: MySQL information_schema 系统库介绍 [打印本页]

作者: MySQL技术    时间: 2021-8-23 15:48
标题: MySQL information_schema 系统库介绍
前言:

当我们安装好 MySQL 数据库后,会发现数据库实例自带有 information_schema 体系库,你是否有去关注过这个体系库呢?是否有查询过此库中的表数据呢?又是否清楚此库存在的具体作用呢?带着这些疑问,我们一起来看本篇文章。

1. information_schema 简介

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

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


                               
登录/注册后可看大图

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

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_DEFAULTFROM    `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 下的表,一定会有收获的。

作者: 勤奋的哼哼    时间: 2021-8-23 16:48
转发了
作者: 时间是贼md    时间: 2021-8-23 16:56
转发了
作者: 吴老师在关注    时间: 2021-8-23 18:29
转发了
作者: ForeverAloneLYH    时间: 2021-8-24 01:06
转发了
作者: lotus520    时间: 2021-8-24 02:18
转发了




欢迎光临 创意电子 (https://www.wxcydz.cc/) Powered by Discuz! X3.4