文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

使用PHP生成MySQL数据字典

2023-09-11 20:14

关注

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

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

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

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

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

我们有强大的PHP啊。

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

";    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;    }

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

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

有好的建议,请在下方输入你的评论。

来源地址:https://blog.csdn.net/qq_39708228/article/details/132324703

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯