zoukankan      html  css  js  c++  java
  • 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 1G
     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 1G
     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

    声明:此博客为个人学习之用,如与其他作品雷同,纯属巧合,转载请指明出处! 

  • 相关阅读:
    AJAX实例演示加载xml
    入门AJAX总结
    My97 DatePicker一款好用的日历控件
    SQL Server 安装错误 错误代码:0x800F0906的解决方案
    JS实现动态添加和删除DIV
    .Net之路(九).ashx来实现ajax用户名的验证
    善良公社项目总结之如何从前台向后台传输数据
    MySQL数据分析(16)— 数据操作之增删改查
    字典-Python基础前传(9)
    MYSQL之事务
  • 原文地址:https://www.cnblogs.com/zhihuifan10/p/12124171.html
Copyright © 2011-2022 走看看