前言:

当我们安装好 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 库,下面分享几条笔者积累的相关查询语句,来看下吧。

# 查看某个库中的表信息
SELECTtable_name,table_type,ENGINE
FROMinformation_schema.TABLES
WHEREtable_schema = 'db5'
ORDER BYtable_name# 查看整个实例占用空间
SELECTconcat( 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
FROMinformation_schema.TABLES;# 查看各个库占用空间
SELECTTABLE_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
FROMinformation_schema.TABLES
GROUP BYTABLE_SCHEMA
ORDER BYdata_length DESC;# 查看某个表占用空间
SELECTconcat( 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
FROMinformation_schema.TABLES
WHEREtable_schema = 'test' AND table_name = 'test_tb'# 查看所有线程信息
SELECT*
FROMinformation_schema.PROCESSLIST# 查看非睡眠线程信息
SELECT*
FROMinformation_schema.PROCESSLIST
WHEREcommand != 'sleep'# 查看某个用户发起的线程信息
SELECT*
FROMinformation_schema.PROCESSLIST
WHEREUSER = 'testuser'# 查看某个字符集支持的所有排序规则
SELECTCOLLATION_NAME,CHARACTER_SET_NAME,IS_DEFAULT
FROM`information_schema`.`COLLATIONS`
WHERE`CHARACTER_SET_NAME` = 'utf8' # 查看某个表的分区信息(如果有)
SELECTTABLE_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*
FROMinformation_schema.INNODB_TRX

总结:

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

转载地址:MySQL information_schema 系统库介绍

MySQL information_schema 系统库介绍相关推荐

  1. MySQL默认数据库介绍

    MySQL默认数据库介绍 大家在学习MySQL时,安装后都会发现里边已经自带了几个默认的数据库,我装的MySQL5.5里边自带六个数据库 网上查了一些资料对这几个数据库的功能做一下学习. 1.info ...

  2. MySQL数据库锁介绍

    MySQL数据库锁介绍 1. 锁的基本概念 当并发事务同时访问一个资源时,有可能导致数据不一致,因此需要一种机制来将数据访问顺序化,以保证数据库数据的一致性. 锁就是其中的一种机制. 我们可以用商场的 ...

  3. MySQL 教程基础介绍

    MySQL 教程基础介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库. 每个数据库都有一个或多个不同的 API 用于创建,访问,管理,搜索和复制所保存的数据. ...

  4. mysql数据库引擎介绍

    mysql数据库引擎介绍 你能用的数据库引擎取决于mysql在安装的时候是如何被编译的.要添加一个新的引擎,就必须重新编译MYSQL.在缺省情况下,MYSQL支持三个引擎:ISAM.MYISAM和HE ...

  5. LAMP架构介绍、MySQL和MariaDB介绍、MySQL安装

    2019独角兽企业重金招聘Python工程师标准>>> LAMP架构介绍 Linux+Apache+MySQL+PHP 就是在linux系统上安装httpd. mysql .PHP, ...

  6. mysql 查询日志介绍

    MySQL查询日志介绍 MySQL的查询日志记录了所有MySQL数据库请求的信息.无论这些请求是否得到了正确的执行.默认文件名为hostname.log.默认情况下MySQL查询日志是关闭的.生产环境 ...

  7. MySQL复制类型介绍

    MySQL复制类型介绍: (1)同步复制:MASTER提交事务,直到事务在所有的Slave都已提交,此时,才会返回给客户端,事务执行完毕. 缺点:完成一个事务可能会有很大的延迟. slave1 MAs ...

  8. MySQL查询日志介绍

    MySQL查询日志介绍 MySQL的查询日志记录了所有MySQL数据库请求的信息.无论这些请求是否得到了正确的执行.默认文件名为hostname.log.默认情况下MySQL查询日志是关闭的.生产环境 ...

  9. MySQL第7天:MySQL的架构介绍之存储引擎

    MySQL的架构介绍之存储引擎 #编写时间:2017.3.9 #编写地点:广州 1.存储引擎相关的命令 //查看已安装的mysql已提供的存储引擎 mysql>show engines;//查看 ...

最新文章

  1. Windows Server 2012
  2. Cheat—— 给Linux初学者和管理员一个终极命令行备忘单
  3. Leetcode 1
  4. 推荐系统炼丹笔记:阿里DMIN多重兴趣网络
  5. MySQL学习笔记01【数据库概念、MySQL安装与使用】
  6. 浅谈文本的相似度问题
  7. 使用gradle-android搭建jenkins slave构建机器常见构建问题(一)
  8. SAP Spartacus delivery mode页面两个一模一样的cart API请求
  9. cups支持的打印机列表_网络存储让你的打印机瞬间变无线,打印文件不用愁
  10. 计算机控制z反变换公式,第三章 计算机控制系统的数学描述(修正Z变换).ppt
  11. 关于@synchronized
  12. 宝塔面板 python管理器2.0安装Mrdoc
  13. CTF密码学——常见编解码及加解密总结
  14. 三角形和矩形傅里叶变换_第3章傅立叶变换.doc
  15. 句子迷,语录,苏引华
  16. python无限制邮件群发软件_有哪些逆天的邮件群发软件推荐?
  17. lamp mysql什么意思_lamp是什么意思
  18. 通过ROS进行多机协同控制
  19. 爬山法求解八皇后问题的全部解法
  20. Google Play上架App设置隐私政策声明问题

热门文章

  1. Java延时队列DelayedQueue
  2. JS手动实现一个new操作符
  3. linux内核部件分析(十)——设备驱动模型之class,linux内核部件分析(十)——设备驱动模型之class...
  4. ntop linux,linux下安装ntop
  5. hosts文件 端口_在Linux系统中使用Vim读写远程文件
  6. Razor 视图引擎学习
  7. JDBC技术总结(一)
  8. FireUIPagedScrollView
  9. gzip,bzip2
  10. Internet Explorer 9 新功能:固定并快速打开常用网站