为什么需要数据字典
通过Navicat等数据库管理工具,我们也能看到数据表的结构设计,但是,如果我们把全部的数据表的结构设计都做成可在线预览的,会不会更加清晰明朗呢,而且也更加容易对比发现问题和及时优化,更有效率。
生成数据字典的方式
这里我主要利用showdoc
在线文档实现数据字典的在线查看,主要说两种实现方式:分别是官方shell脚本和我写的PHP脚本;
- 官方shell脚本:仅支持在Linux服务器中运行,官方的文档地址:https://www.showdoc.com.cn/page/312209902620725
- 我写的PHP脚本:不管是在Linux还是在Windows等操作系统中都支持,而且更加灵活可控
官方的脚本运行方式也比较简单,看看文档即明白,我下面主要说一下我写的PHP脚本的思路和运行方式,也就是利用showdoc
提供的开放API接口实现将数据结构的信息以Markdown的格式上传到指定项目,文档地址:https://www.showdoc.com.cn/page/102098
关键信息配置
因为连接数据库的配置信息以及需要上传的项目地址也不同,所以这些信息需要单独配置,具体我也不多说了,看下面代码及注释信息即可
1 | // 数据库连接配置信息 |
连接和关闭MySQL数据库
为了方便快速跨平台使用,我使用的都是PHP原生的写法,所以,连接数据库以及查询数据都是使用原生的PHP写法,利用PHP类的语法特性,在构造函数中连接数据库并且在析构函数中关闭连接。
1 | /** |
查询表结构信息
连接上了数据库,那么我们就可以查询利用Sql
语句数据库信息相关信息,利用语句show table status;
可以查出当前连接库的全部数据表信息,然后再查询information_schema.COLUMNS
表上具体某个表的数据结构信息,并组装数组返回使用。
1 | /** |
通过API接口上传到项目
获取到表的数据结构信息,我们就可以拼装字段信息,并且通过开放API接口上传到执行的项目中,大家可以看我的一个测试的项目https://www.showdoc.com.cn/1383736300665067,大家需要上传到自己的项目,只需要按照上面的说明修改相关配置即可,如果不想上传到showdoc
官方的域名,可以自己利用开源代码搭建到自己的服务器上,然后部署好,上传到自己搭建的项目中也可以,具体可以查看相关的文档。
1 | /** |
脚本执行核心处理
上面的数据获取以及上传方法有了,那么就可以将全部的表结构字段进行循环处理,拼装成Markdown的格式,上传到项目中。开放API接口有请求频率限制,也就是10分钟只能请求1000次,所以,如果单次请求过多的话,需要做频率控制,防止请求失败,未能成功上传到项目中。
1 | /** |
完整源码
上面的拆分部分,基本已经把核心的代码都列出来了,但是为了大家更方便快捷的使用以及反馈问题,一键复制完整源码直接运行,我把代码上传到交友网站了Github,同时,也把完整源码贴在下面,请叫我当代活雷锋……(我也不容易,别吐槽我用代码占用大量篇幅了)
1 |
|
最后
任何的工具,都是为了方便你我他,希望大家能相处更多更好的工具以及办法,更好更快的完成工作内容,大家有什么好的想法也可以和我分享,一起集思广益,发现问题并及时解决,谢谢。