乐趣区

关于mysql:MySQL-informationschema-系统库介绍

前言:

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

1. information_schema 简介

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

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

能够很显著看出,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 下的表,肯定会有播种的。

退出移动版