mysql怎么给表做说明_mysql中的information_schema数据库表说明

1. 概述

information_schema 数据库跟 performance_schema 一样,都是 MySQL 自带的信息数据库。其中 performance_schema 用于性能分析,而 information_schema 用于存储数据库元数据(关于数据的数据),例如数据库名、表名、列的数据类型、访问权限等。

information_schema 中的表实际上是视图,而不是基本表,因此,文件系统上没有与之相关的文件。

1 mysql>use information_schema;

2 Reading table information forcompletion 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.00sec)

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

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值