使用PHP生成MySQL数据字典

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 给大家分享一个自己写的函数:使用PHP生成mysql字典。

QQ图片20220426174350.jpg

一个项目完成之后,按照需求,我需要给这个项目写设计文档,数据库字典。


设计文档到时好说,但是数据库字典可真的是有点吓到我了。


项目开始的比较急,最开始建数据库的时候没有用excel写数据库字典。


这几十张表的数据库,一个一个的写,那真的是酸爽。


但是,这一切好像又都不是事。


我们有强大的PHP啊。


下面给大家分享一个自己写的函数:使用PHP生成mysql字典。


<?php
    $dbhost = '127.0.0.1:3306';                         // mysql服务器主机地址
    $dbuser = 'root';                                 // mysql用户名
    $dbpass = 'root';                         // mysql用户名密码
    $dbname = "shopxo";
    //$mysql = mysqli_connect($dbhost, $dbuser, $dbpass);//这是mysql的链接方法
    $mysql = new mysqli("localhost", $dbuser,$dbpass,$dbname, "3306"); //这是mysqli的链接方法
    if(! $mysql )
    {
        die('连接失败: ' . mysqli_error($mysql));
    }
    $html = expertDirectory($mysql,$dbname);
    echo "<pre>";
    var_dump($html);
    /**
     * 导出数据库字典
     */
    function expertDirectory($mysql,$dbname)
    {
        mysqli_query($mysql, "set names utf8");
        $table_result = $mysql->query('show tables');
        $no_show_table = array();    //不需要显示的表
        $no_show_field = array();   //不需要显示的字段
        //取得所有的表名
        while($row = mysqli_fetch_array($table_result)){
            if(!in_array($row[0],$no_show_table)){
            $tables[]['TABLE_NAME'] = $row[0];
          }
        }
        //替换所以表的表前缀
        // if($_GET['prefix']){
        //  $prefix = 'sent_';
        //  foreach($tables as $key => $val){
        //    $tableName = $val['TABLE_NAME'];
        //    $string = explode('_',$tableName);
        //    if($string[0] != $prefix){ 
        //      $string[0] = $prefix; 
        //      $newTableName = implode('_', $string); 
        //      $mysql->query('rename table '.$tableName.' TO '.$newTableName); 
        //    }
        //  }
        //  echo "替换成功!";exit();
        // }
        //循环取得所有表的备注及表中列消息
        foreach ($tables as $k=>$v) {
            $sql  = 'SELECT * FROM ';
            $sql .= 'INFORMATION_SCHEMA.TABLES ';
            $sql .= 'WHERE ';
            $sql .= "table_name = '{$v['TABLE_NAME']}'  AND table_schema = '{$dbname}'";
            $table_result = $mysql->query($sql);
            while ($t = mysqli_fetch_array($table_result) ) {
                $tables[$k]['TABLE_COMMENT'] = $t['TABLE_COMMENT'];
            }
            $sql  = 'SELECT * FROM ';
            $sql .= 'INFORMATION_SCHEMA.COLUMNS ';
            $sql .= 'WHERE ';
            $sql .= "table_name = '{$v['TABLE_NAME']}' AND table_schema = '{$dbname}'";
            $fields = array();
            $field_result = $mysql->query($sql);
            while ($t = mysqli_fetch_array($field_result) ) {
                $fields[] = $t;
            }
            $tables[$k]['COLUMN'] = $fields;
        }
        // $mysql->close($mysql_conn);
        $html = '';
        //循环所有表
        foreach ($tables as $k=>$v) {
            $html .= '  ' . ($k + 1) . '、' . $v['TABLE_COMMENT'] .'  ('. $v['TABLE_NAME']. ')'."
";
            $html .= '  '."
";
            $html .= '    '."
";
          $html .= '      '."
";
          $html .= '        字段名'."
";
          $html .= '        数据类型'."
";
          $html .= '        默认值'."
";
          $html .= '        允许非空'."
";
          $html .= '        自动递增'."
";
          $html .= '        备注'."
";
          $html .= '      '."
";
            foreach ($v['COLUMN'] as $f) {
            if(!@is_array($no_show_field[$v['TABLE_NAME']])){
              $no_show_field[$v['TABLE_NAME']] = array();
            }
            if(!in_array($f['COLUMN_NAME'],$no_show_field[$v['TABLE_NAME']])){
              $html .= '      '."
";
              $html .= '        ' . $f['COLUMN_NAME'] . ''."
";
              $html .= '        ' . $f['COLUMN_TYPE'] . ''."
";
              $html .= '        ' . $f['COLUMN_DEFAULT'] . ''."
";
              $html .= '        ' . $f['IS_NULLABLE'] . ''."
";
              $html .= '        ' . ($f['EXTRA']=='auto_increment'?'是':' ') . ''."
";
              $html .= '        ' . $f['COLUMN_COMMENT'] . ''."
";
              $html .= '      '."
";
            }
            }
            $html .= '    '."
";
          $html .= '  '."
";
        }
        return $html;
    }


其实这只是一个简单的小函数,平时用到的几率也不大。


但是,在需要的时候,他会给你省很多力气。


相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
目录
相关文章
|
5月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
3月前
|
SQL 人工智能 关系型数据库
如何实现MySQL百万级数据的查询?
本文探讨了在MySQL中对百万级数据进行排序分页查询的优化策略。面对五百万条数据,传统的浅分页和深分页查询效率较低,尤其深分页因偏移量大导致性能显著下降。通过为排序字段添加索引、使用联合索引、手动回表等方法,有效提升了查询速度。最终建议根据业务需求选择合适方案:浅分页可加单列索引,深分页推荐联合索引或子查询优化,同时结合前端传递最后一条数据ID的方式实现高效翻页。
144 0
|
16天前
|
关系型数据库 MySQL PHP
PHP和Mysql前后端交互效果实现
本文介绍了使用PHP连接MySQL数据库的基本函数及其实现案例。内容涵盖数据库连接、选择数据库、执行查询、获取结果等常用操作,并通过用户登录和修改密码的功能实例,展示了PHP与MySQL的交互过程及代码实现。
151 0
PHP和Mysql前后端交互效果实现
|
4月前
|
JSON 数据处理 PHP
PHP数组处理技巧:高效操作数据集合
PHP数组处理技巧:高效操作数据集合
|
4月前
|
JSON 安全 大数据
PHP中的数组处理艺术:灵活高效的数据操作
PHP中的数组处理艺术:灵活高效的数据操作
|
2月前
|
存储 关系型数据库 MySQL
在CentOS 8.x上安装Percona Xtrabackup工具备份MySQL数据步骤。
以上就是在CentOS8.x上通过Perconaxtabbackup工具对Mysql进行高效率、高可靠性、无锁定影响地实现在线快速全量及增加式数据库资料保存与恢复流程。通过以上流程可以有效地将Mysql相关资料按需求完成定期或不定期地保存与灾难恢复需求。
153 10
|
4月前
|
JSON 定位技术 PHP
PHP技巧:解析JSON及提取数据
这就是在PHP世界里探索JSON数据的艺术。这场狩猎不仅仅是为了获得数据,而是一种透彻理解数据结构的行动,让数据在你的编码海洋中畅游。通过这次冒险,你已经掌握了打开数据宝箱的钥匙。紧握它,让你在编程世界中随心所欲地航行。
154 67
|
3月前
|
SQL 存储 缓存
MySQL 如何高效可靠处理持久化数据
本文详细解析了 MySQL 的 SQL 执行流程、crash-safe 机制及性能优化策略。内容涵盖连接器、分析器、优化器、执行器与存储引擎的工作原理,深入探讨 redolog 与 binlog 的两阶段提交机制,并分析日志策略、组提交、脏页刷盘等关键性能优化手段,帮助提升数据库稳定性与执行效率。
|
6月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
276 28
|
6月前
|
关系型数据库 MySQL Linux
查看Linux、Apache、MySQL、PHP版本的技巧
以上就是查看Linux、Apache、MySQL、PHP版本信息的方法。希望这些信息能帮助你更好地理解和使用你的LAMP技术栈。
298 17

热门文章

最新文章

推荐镜像

更多