1. 程式人生 > 其它 >MySQL information_schema 系統庫介紹

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 儲存引擎,再仔細看這些表的建立語句,發現這些表都是臨時表。下面展示部分表的作用:

  • 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 下的表,一定會有收穫的。

作者:MySQL技術
出處:https://www.cnblogs.com/kunjian/
本文版權歸作者和部落格園共有,歡迎轉載,但未經作者同意必須保留此段宣告,且在文章頁面明顯位置給出原文連線,否則保留追究法律責任的權利。
如果文中有什麼錯誤,歡迎指出。以免更多的人被誤導。有需要溝通的,可以站內私信,文章留言,或者關注『MySQL技術』公眾號私信我。一定盡力回答。