1. 程式人生 > >MySQL中的information_schema資料庫表說明

MySQL中的information_schema資料庫表說明

 

MySQL 中的 information_schema 資料庫

 

1. 概述

information_schema 資料庫跟 performance_schema 一樣,都是 MySQL 自帶的資訊資料庫。其中 performance_schema 用於效能分析,而 information_schema 用於儲存資料庫元資料(關於資料的資料),例如資料庫名、表名、列的資料型別、訪問許可權等。

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

mysql> use information_schema;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> show tables;
+---------------------------------------+
| Tables_in_information_schema          |
+---------------------------------------+
| CHARACTER_SETS                        |
| COLLATIONS                            |
| COLLATION_CHARACTER_SET_APPLICABILITY |
| COLUMNS | | COLUMN_PRIVILEGES | | ENGINES | | EVENTS | | FILES | | GLOBAL_STATUS | | GLOBAL_VARIABLES | | KEY_COLUMN_USAGE | | OPTIMIZER_TRACE | | PARAMETERS | | PARTITIONS | | PLUGINS | | PROCESSLIST | | PROFILING | | REFERENTIAL_CONSTRAINTS | | ROUTINES | | SCHEMATA | | SCHEMA_PRIVILEGES | | SESSION_STATUS | | SESSION_VARIABLES | | STATISTICS | | TABLES | | TABLESPACES | | TABLE_CONSTRAINTS | | TABLE_PRIVILEGES | | TRIGGERS | | USER_PRIVILEGES | | VIEWS | | INNODB_LOCKS | | INNODB_TRX | | INNODB_SYS_DATAFILES | | INNODB_FT_CONFIG | | INNODB_SYS_VIRTUAL | | INNODB_CMP | | INNODB_FT_BEING_DELETED | | INNODB_CMP_RESET | | INNODB_CMP_PER_INDEX | | INNODB_CMPMEM_RESET | | INNODB_FT_DELETED | | INNODB_BUFFER_PAGE_LRU | | INNODB_LOCK_WAITS | | INNODB_TEMP_TABLE_INFO | | INNODB_SYS_INDEXES | | INNODB_SYS_TABLES | | INNODB_SYS_FIELDS | | INNODB_CMP_PER_INDEX_RESET | | INNODB_BUFFER_PAGE | | INNODB_FT_DEFAULT_STOPWORD | | INNODB_FT_INDEX_TABLE | | INNODB_FT_INDEX_CACHE | | INNODB_SYS_TABLESPACES | | INNODB_METRICS | | INNODB_SYS_FOREIGN_COLS | | INNODB_CMPMEM | | INNODB_BUFFER_POOL_STATS | | INNODB_SYS_COLUMNS | | INNODB_SYS_FOREIGN | | INNODB_SYS_TABLESTATS | +---------------------------------------+ 61 rows in set (0.00 sec)

2. information_schema 庫中常用的表

CHARACTER_SETS 表

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

mysql> SHOW CHARACTER SET; mysql> SELECT * FROM CHARACTER_SETS;

SCHEMATA 表

當前mysql例項中所有資料庫。SHOW DATABASES; 命令從這個表獲取資料。

mysql> SELECT * FROM SCHEMATA; mysql> show databases;

TABLES 表

儲存資料庫中的表資訊(包括檢視),包括表屬於哪個資料庫,表的型別、儲存引擎、建立時間等資訊。SHOW TABLES FROM XX; 命令從這個表獲取結果。

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

COLUMNS 表

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

mysql> SELECT * FROM COLUMNS LIMIT 2,5;

STATISTICS 表

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

mysql> SHOW INDEX FROM szhuizhong.users;

USER_PRIVILEGES 表

使用者許可權表。內容源自 mysql.user 授權表。是非標準表。

mysql> SELECT * FROM USER_PRIVILEGES;

SCHEMA_PRIVILEGES 表

方案許可權表。給出了關於方案(資料庫)許可權的資訊。內容來自 mysql.db 授權表。是非標準表。

mysql> SELECT * FROM SCHEMA_PRIVILEGES;

TABLE_PRIVILEGES 表

表許可權表。給出了關於表許可權的資訊。內容源自 mysql.tables_priv 授權表。是非標準表。

mysql> SELECT * FROM TABLE_PRIVILEGES;

COLUMN_PRIVILEGES 表

列許可權表。給出了關於列許可權的資訊。內容源自 mysql.columns_priv 授權表。是非標準表。

mysql> SELECT * FROM COLUMN_PRIVILEGES;

COLLATIONS 表

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

mysql> SELECT * FROM COLLATIONS;

COLLATION_CHARACTER_SET_APPLICABILITY 表

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

mysql> SELECT * FROM COLLATION_CHARACTER_SET_APPLICABILITY;

TABLE_CONSTRAINTS 表

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

mysql> SELECT * FROM TABLE_CONSTRAINTS;

KEY_COLUMN_USAGE 表

描述了具有約束的鍵列。

mysql> SELECT * FROM KEY_COLUMN_USAGE;

ROUTINES 表

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

VIEWS 表

給出了關於資料庫中的檢視的資訊。需要有 show views 許可權,否則無法檢視檢視資訊。

mysql> SELECT * FROM VIEWS LIMIT 1\G
*************************** 1. row ***************************
       TABLE_CATALOG: def
        TABLE_SCHEMA: sys
 TABLE_NAME: host_summary  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`)  CHECK_OPTION: NONE  IS_UPDATABLE: NO  DEFINER: [email protected]  SECURITY_TYPE: INVOKER CHARACTER_SET_CLIENT: utf8 COLLATION_CONNECTION: utf8_general_ci 1 row in set (0.03 sec)

TRIGGERS 表

提供了關於觸發程式的資訊。必須有 super 許可權才能檢視該表。

mysql> SELECT * FROM TRIGGERS LIMIT 1\G
*************************** 1. row ***************************
           TRIGGER_CATALOG: def
            TRIGGER_SCHEMA: sys
              TRIGGER_NAME: sys_config_insert_set_user
        EVENT_MANIPULATION: INSERT
      EVENT_OBJECT_CATALOG: def
       EVENT_OBJECT_SCHEMA: sys
        EVENT_OBJECT_TABLE: sys_config
              ACTION_ORDER: 1
          ACTION_CONDITION: NULL 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 ACTION_ORIENTATION: ROW ACTION_TIMING: BEFORE ACTION_REFERENCE_OLD_TABLE: NULL ACTION_REFERENCE_NEW_TABLE: NULL ACTION_REFERENCE_OLD_ROW: OLD ACTION_REFERENCE_NEW_ROW: NEW CREATED: 2017-05-27 11:18:43.60 SQL_MODE: DEFINER: [email protected] CHARACTER_SET_CLIENT: utf8 COLLATION_CONNECTION: utf8_general_ci DATABASE_COLLATION: utf8_general_ci 1 row in set (0.00 sec)







information_schema資料庫表說明:

SCHEMATA表:提供了當前mysql例項中所有資料庫的資訊。是show databases的結果取之此表。

TABLES表:提供了關於資料庫中的表的資訊(包括檢視)。詳細表述了某個表屬於哪個schema,表型別,表引擎,建立時間等資訊。是show tables from schemaname的結果取之此表。

COLUMNS表:提供了表中的列資訊。詳細表述了某張表的所有列以及每個列的資訊。是show columns from schemaname.tablename的結果取之此表。

STATISTICS表:提供了關於表索引的資訊。是show index from schemaname.tablename的結果取之此表。

USER_PRIVILEGES(使用者許可權)表:給出了關於全程許可權的資訊。該資訊源自mysql.user授權表。是非標準表。

SCHEMA_PRIVILEGES(方案許可權)表:給出了關於方案(資料庫)許可權的資訊。該資訊來自mysql.db授權表。是非標準表。

TABLE_PRIVILEGES(表許可權)表:給出了關於表許可權的資訊。該資訊源自mysql.tables_priv授權表。是非標準表。

COLUMN_PRIVILEGES(列許可權)表:給出了關於列許可權的資訊。該資訊源自mysql.columns_priv授權表。是非標準表。

CHARACTER_SETS(字符集)表:提供了mysql例項可用字符集的資訊。是SHOW CHARACTER SET結果集取之此表。

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

COLLATION_CHARACTER_SET_APPLICABILITY表:指明瞭可用於校對的字符集。這些列等效於SHOW COLLATION的前兩個顯示欄位。

TABLE_CONSTRAINTS表:描述了存在約束的表。以及表的約束型別。

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

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

VIEWS表:給出了關於資料庫中的檢視的資訊。需要有show views許可權,否則無法檢視檢視資訊。

TRIGGERS表:提供了關於觸發程式的資訊。必須有super許可權才能檢視該表。







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表:提供了關於觸發程式的資訊。






讓普通使用者登入phpmyadmin不顯示information_schema
如果不想在phpMyAdmin中顯示的話只需要設定在config.inc.php(有的是config.default.php)中設定這樣一句
$cfg['Servers'][$i]['hide_db'] = 'information_schema';