当前位置:   article > 正文

Mysql生成数据字典_mysql数据字典生成

mysql数据字典生成

实现原理

在MySQL中,有个自带的数据库,名为information_schema。其中保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权 限等。我们通过查询这个数据库的COLUMNS表(此表提供了其他所有表中的列信息)信息,来获取我们需要的表结构信息,从而将其导出为数据字典。

实现案例

navicat 执行以下SQL的查询(如果需要其他字段,请参考下面COLUMNS表字段拓展):

  1. SELECT
  2. COLUMN_NAME AS '字段名',
  3. COLUMN_TYPE AS '字段类型',
  4. ( CASE WHEN IS_NULLABLE = 'YES' THEN '是' ELSE '否' END ) AS '是否可空',
  5. ( CASE WHEN COLUMN_KEY = 'PRI' THEN '是' ELSE '否' END ) AS '是否主键',
  6. COLUMN_DEFAULT AS '默认值',
  7. COLUMN_COMMENT AS '注释'
  8. FROM
  9. INFORMATION_SCHEMA.COLUMNS
  10. WHERE
  11. TABLE_SCHEMA = '数据库'
  12. AND TABLE_NAME = '表';

通过navicat工具进行导出(如下图的按钮,之后自行选择要导出的内容);

 

COLUMNS表字段拓展:

列名描述
COLUMN_NAME字段名
COLUMN_TYPE字段类型
TABLE_CATALOG表限定符。
IS_NULLABLE列的为空性。如果列允许 NULL,那么该列返回 YES。否则,返回 NO。
COLUMN_KEY字段主键
COLUMN_DEFAULT默认值
COLUMN_COMMENT注释
ORDINAL_POSITION字段在表的顺序(从1开始)
TABLE_NAME数据表名
TABLE_SCHEMA数据库名
DATA_TYPE数据类型
DATETIME_PRECISIONdatetime 及 SQL-92 interval 数据类型的子类型代码。对于其它数据类型,返回 NULL。
EXTRA额外信息
GENERATION_EXPRESSION
NUMERIC_PRECISION近似数字数据、精确数字数据、整型数据或货币数据的精度。否则,返回 NULL。
NUMERIC_SCALE近似数字数据、精确数字数据、整数数据或货币数据的小数位数。否则,返回 NULL。
PRIVILEGES
CHARACTER_MAXIMUM_LENGTH以字符为单位的最大长度,适于二进制数据、字符数据,或者文本和图像数据。否则,返回NULL。
CHARACTER_OCTET_LENGTH以字节为单位的最大长度,适于二进制数据、字符数据,或者文本和图像数据。否则,返回 NULL。
CHARACTER_SET_NAME如果该列是字符数据或 text数据类型,那么为字符集返回唯一的名称。否则,返回 NULL。
COLLATION_NAME排序规则,如果列是字符数据或 text数据类型,那么为排序次序返回唯一的名称。否则,返回 NULL。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/2023面试高手/article/detail/628265
推荐阅读
相关标签
  

闽ICP备14008679号