Mysql生成数据字典
生成原理
在MySQL中,有个自带的数据库,名为information_schema。其中保存着关于MySQL服务器所维护的所有其他数据库的信息。如数据库名,数据库的表,表栏的数据类型与访问权 限等。我们通过查询这个数据库的COLUMNS表(此表提供了其他所有表中的列信息)信息,来获取我们需要的表结构信息,从而将其导出为数据字典。
生成实例
navicat 执行以下SQL的查询(如果需要其他字段,请参考下面COLUMNS表字段拓展):
1 SELECT 2COLUMN_NAME AS '字段名', 3COLUMN_TYPE AS '字段类型', 4( CASE WHEN IS_NULLABLE = 'YES' THEN '是' ELSE '否' END ) AS '是否可空', 5( CASE WHEN COLUMN_KEY = 'PRI' THEN '是' ELSE '否' END ) AS '是否主键', 6COLUMN_DEFAULT AS '默认值', 7COLUMN_COMMENT AS '注释' 8 FROM 9INFORMATION_SCHEMA.COLUMNS 10 WHERE 11TABLE_SCHEMA = '数据库' 12AND 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_PRECISION | datetime 及 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。 |
推荐阅读
- 有了jmespath,处理python中的json数据就变成了一种享受...
- centOS|centOS 7 离线安装 MySQL 5.6 完美安装
- 海量数据分析更快、更稳、更准。GaussDB(for|海量数据分析更快、更稳、更准。GaussDB(for MySQL) HTAP只读分析特性详解
- 经典程序|数据结构之用栈来解决括号匹配问题(Java实现)
- 线性表|大学数据结构之顺序表的实现(Java版本)
- 经典程序|数据结构之双向链表(Java实现)
- 数据结构|数据结构之单链表的实现(Java版本)
- 经典程序|利用C语言创建数据结构中链表的遍历及其基本操作
- 数据结构与算法|4 单循环链表解决约瑟夫问题
- 数据结构|数据结构(循环链表解决约瑟夫问题)