mysql中的information_schema數據庫表說明


1. 概述

information_schema 數據庫跟 performance_schema 一樣,都是 MySQL 自帶的信息數據庫。其中 performance_schema 用於性能分析,而 information_schema 用於存儲數據庫元數據(關於數據的數據),例如數據庫名、表名、列的數據類型、訪問權限等。

 

information_schema 中的表實際上是視圖,而不是基本表,因此,文件系統上沒有與之相關的文件。

 1 mysql> use information_schema;
 2 Reading table information for completion of table and column names 3 You can turn off this feature to get a quicker startup with -A 4 5 Database changed 6 mysql> show tables; 7 +---------------------------------------+ 8 | Tables_in_information_schema | 9 +---------------------------------------+ 10 | CHARACTER_SETS | 11 | COLLATIONS | 12 | COLLATION_CHARACTER_SET_APPLICABILITY | 13 | COLUMNS | 14 | COLUMN_PRIVILEGES | 15 | ENGINES | 16 | EVENTS | 17 | FILES | 18 | GLOBAL_STATUS | 19 | GLOBAL_VARIABLES | 20 | KEY_COLUMN_USAGE | 21 | OPTIMIZER_TRACE | 22 | PARAMETERS | 23 | PARTITIONS | 24 | PLUGINS | 25 | PROCESSLIST | 26 | PROFILING | 27 | REFERENTIAL_CONSTRAINTS | 28 | ROUTINES | 29 | SCHEMATA | 30 | SCHEMA_PRIVILEGES | 31 | SESSION_STATUS | 32 | SESSION_VARIABLES | 33 | STATISTICS | 34 | TABLES | 35 | TABLESPACES | 36 | TABLE_CONSTRAINTS | 37 | TABLE_PRIVILEGES | 38 | TRIGGERS | 39 | USER_PRIVILEGES | 40 | VIEWS | 41 | INNODB_LOCKS | 42 | INNODB_TRX | 43 | INNODB_SYS_DATAFILES | 44 | INNODB_FT_CONFIG | 45 | INNODB_SYS_VIRTUAL | 46 | INNODB_CMP | 47 | INNODB_FT_BEING_DELETED | 48 | INNODB_CMP_RESET | 49 | INNODB_CMP_PER_INDEX | 50 | INNODB_CMPMEM_RESET | 51 | INNODB_FT_DELETED | 52 | INNODB_BUFFER_PAGE_LRU | 53 | INNODB_LOCK_WAITS | 54 | INNODB_TEMP_TABLE_INFO | 55 | INNODB_SYS_INDEXES | 56 | INNODB_SYS_TABLES | 57 | INNODB_SYS_FIELDS | 58 | INNODB_CMP_PER_INDEX_RESET | 59 | INNODB_BUFFER_PAGE | 60 | INNODB_FT_DEFAULT_STOPWORD | 61 | INNODB_FT_INDEX_TABLE | 62 | INNODB_FT_INDEX_CACHE | 63 | INNODB_SYS_TABLESPACES | 64 | INNODB_METRICS | 65 | INNODB_SYS_FOREIGN_COLS | 66 | INNODB_CMPMEM | 67 | INNODB_BUFFER_POOL_STATS | 68 | INNODB_SYS_COLUMNS | 69 | INNODB_SYS_FOREIGN | 70 | INNODB_SYS_TABLESTATS | 71 +---------------------------------------+ 72 61 rows in set (0.00 sec)

 

2. information_schema 庫中常用的表

 

CHARACTER_SETS 表 

可用字符集。SHOW CHARACTER SET; 命令從這個表獲取結果。

1 mysql> SHOW CHARACTER SET;
2  
3 mysql> SELECT * FROM CHARACTER_SETS;

 

SCHEMATA 表 

當前mysql實例中所有數據庫。SHOW DATABASES; 命令從這個表獲取數據。

1 mysql> SELECT * FROM SCHEMATA;
2  
3 mysql> show databases;

 

TABLES 表

存儲數據庫中的表信息(包括視圖),包括表屬於哪個數據庫,表的類型、存儲引擎、創建時間等信息。SHOW TABLES FROM XX; 命令從這個表獲取結果。

1 mysql> SELECT * FROM TABLES;
2 mysql> SHOW TABLES FROM zentao;

 

COLUMNS 表  

存儲表中的列信息,包括表有多少列、每個列的類型等。SHOW COLUMNS FROM schemaname.tablename 命令從這個表獲取結果。

1 mysql> SELECT * FROM COLUMNS LIMIT 2,5;

 

STATISTICS 表 

表索引的信息。SHOW INDEX FROM schemaname.tablename; 命令從這個表獲取結果。

1 SHOW INDEX FROM szhuizhong.users;

 

USER_PRIVILEGES 表 

用戶權限表。內容源自 mysql.user 授權表。是非標准表。

1 SELECT * FROM USER_PRIVILEGES;

 

SCHEMA_PRIVILEGES 表

方案權限表。給出了關於方案(數據庫)權限的信息。內容來自 mysql.db 授權表。是非標准表。

1 mysql> SELECT * FROM SCHEMA_PRIVILEGES;

 

TABLE_PRIVILEGES 表

表權限表。給出了關於表權限的信息。內容源自 mysql.tables_priv 授權表。是非標准表。

1 mysql> SELECT * FROM TABLE_PRIVILEGES;

 

COLUMN_PRIVILEGES 表

列權限表。給出了關於列權限的信息。內容源自 mysql.columns_priv 授權表。是非標准表。 

1 mysql> SELECT * FROM COLUMN_PRIVILEGES;

 

COLLATIONS 表

提供了關於各字符集的對照信息。SHOW COLLATION; 命令從這個表獲取結果。

1 mysql> SELECT * FROM COLLATIONS;

 

COLLATION_CHARACTER_SET_APPLICABILITY 表

指明了可用於校對的字符集。相當於 SHOW COLLATION 命令結果的前兩個字段。

1 mysql> SELECT * FROM COLLATION_CHARACTER_SET_APPLICABILITY;

 

TABLE_CONSTRAINTS 表

描述了存在約束的表。以及表的約束類型。

1 mysql> SELECT * FROM TABLE_CONSTRAINTS;

 

KEY_COLUMN_USAGE 表

描述了具有約束的鍵列。

1 mysql> SELECT * FROM KEY_COLUMN_USAGE;

 

ROUTINES 表

提供了關於存儲子程序(存儲程序和函數)的信息。此時,ROUTINES 表不包含自定義函數(UDF)。名為“mysql.proc name”的列指明了對應於 INFORMATION_SCHEMA.ROUTINES 表的 mysql.proc 列。

 

VIEWS 表 

給出了關於數據庫中的視圖的信息。需要有 show views 權限,否則無法查看視圖信息。

 1 mysql> SELECT * FROM VIEWS LIMIT 1\G
 2 *************************** 1. row ***************************
 3  TABLE_CATALOG: def 4  TABLE_SCHEMA: sys 5  TABLE_NAME: host_summary 6 VIEW_DEFINITION: select if(isnull(`performance_schema`.`accounts`.`HOST`),'background',`performance_schema`.`accounts`.`HOST`) AS `host`,sum(`stmt`.`total`) AS `statements`,`sys`.`format_time`(sum(`stmt`.`total_latency`)) AS `statement_latency`,`sys`.`format_time`(ifnull((sum(`stmt`.`total_latency`) / nullif(sum(`stmt`.`total`),0)),0)) AS `statement_avg_latency`,sum(`stmt`.`full_scans`) AS `table_scans`,sum(`io`.`ios`) AS `file_ios`,`sys`.`format_time`(sum(`io`.`io_latency`)) AS `file_io_latency`,sum(`performance_schema`.`accounts`.`CURRENT_CONNECTIONS`) AS `current_connections`,sum(`performance_schema`.`accounts`.`TOTAL_CONNECTIONS`) AS `total_connections`,count(distinct `performance_schema`.`accounts`.`USER`) AS `unique_users`,`sys`.`format_bytes`(sum(`mem`.`current_allocated`)) AS `current_memory`,`sys`.`format_bytes`(sum(`mem`.`total_allocated`)) AS `total_memory_allocated` from (((`performance_schema`.`accounts` join `sys`.`x$host_summary_by_statement_latency` `stmt` on((`performance_schema`.`accounts`.`HOST` = `stmt`.`host`))) join `sys`.`x$host_summary_by_file_io` `io` on((`performance_schema`.`accounts`.`HOST` = `io`.`host`))) join `sys`.`x$memory_by_host_by_current_bytes` `mem` on((`performance_schema`.`accounts`.`HOST` = `mem`.`host`))) group by if(isnull(`performance_schema`.`accounts`.`HOST`),'background',`performance_schema`.`accounts`.`HOST`) 7  CHECK_OPTION: NONE 8  IS_UPDATABLE: NO 9  DEFINER: mysql.sys@localhost 10  SECURITY_TYPE: INVOKER 11 CHARACTER_SET_CLIENT: utf8 12 COLLATION_CONNECTION: utf8_general_ci 13 1 row in set (0.03 sec)

 

TRIGGERS 表

提供了關於觸發程序的信息。必須有 super 權限才能查看該表。

 1 mysql> SELECT * FROM TRIGGERS LIMIT 1\G
 2 *************************** 1. row ***************************
 3  TRIGGER_CATALOG: def 4  TRIGGER_SCHEMA: sys 5  TRIGGER_NAME: sys_config_insert_set_user 6  EVENT_MANIPULATION: INSERT 7  EVENT_OBJECT_CATALOG: def 8  EVENT_OBJECT_SCHEMA: sys 9  EVENT_OBJECT_TABLE: sys_config 10 ACTION_ORDER: 1 11  ACTION_CONDITION: NULL 12 ACTION_STATEMENT: BEGIN IF @sys.ignore_sys_config_triggers != true AND NEW.set_by IS NULL THEN SET NEW.set_by = USER(); END IF; END 13  ACTION_ORIENTATION: ROW 14  ACTION_TIMING: BEFORE 15 ACTION_REFERENCE_OLD_TABLE: NULL 16 ACTION_REFERENCE_NEW_TABLE: NULL 17  ACTION_REFERENCE_OLD_ROW: OLD 18  ACTION_REFERENCE_NEW_ROW: NEW 19 CREATED: 2017-05-27 11:18:43.60 20  SQL_MODE: 21  DEFINER: mysql.sys@localhost 22  CHARACTER_SET_CLIENT: utf8 23  COLLATION_CONNECTION: utf8_general_ci 24  DATABASE_COLLATION: utf8_general_ci 25 1 row in set (0.00 sec)

 

SCHEMATA表:提供了關於數據庫的信息。

TABLES表:給出了關於數據庫中的表的信息。

COLUMNS表:給出了表中的列信息。

STATISTICS表:給出了關於表索引的信息。

USER_PRIVILEGES表:給出了關於全程權限的信息。該信息源自mysql.user授權表。

SCHEMA_PRIVILEGES表:給出了關於方案(數據庫)權限的信息。該信息來自mysql.db授權表。

TABLE_PRIVILEGES表:給出了關於表權限的信息。該信息源自mysql.tables_priv授權表。

COLUMN_PRIVILEGES表:給出了關於列權限的信息。該信息源自mysql.columns_priv授權表。

CHARACTER_SETS表:提供了關於可用字符集的信息。

COLLATIONS表:提供了關於各字符集的對照信息。

COLLATION_CHARACTER_SET_APPLICABILITY表:指明了可用於校對的字符集。

TABLE_CONSTRAINTS表:描述了存在約束的表。

KEY_COLUMN_USAGE表:描述了具有約束的鍵列。

ROUTINES表:提供了關於存儲子程序(存儲程序和函數)的信息。此時,ROUTINES表不包含自定義函數(UDF)。

VIEWS表:給出了關於數據庫中的視圖的信息。 

TRIGGERS表:提供了關於觸發程序的信息。  

 

information_schema 中字段(TABLE_CATALOG)說明:

MySQL系統表中,很多表都存在TABLE_CATALOG字段,MYSQL官方文檔中說,這個字段值永遠是def,但沒寫這個字段是干嘛用的。

網上有把這個叫表限定符的,有叫登記目錄的。作用疑似是和其他種類的數據庫做區分。

 

 

原文鏈接:

https://blog.csdn.net/weixin_34248258/article/details/86030186

https://blog.csdn.net/lkforce/article/details/79557482

 

 

聲明:此博客為個人學習之用,如與其他作品雷同,純屬巧合,轉載請指明出處! 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM