使用PHP生成MySQL数据字典

这篇具有很好参考价值的文章主要介绍了使用PHP生成MySQL数据字典。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

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

项目开始的比较急,最开始建数据库的时候没有用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;
    }

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

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

有好的建议,请在下方输入你的评论。文章来源地址https://www.toymoban.com/news/detail-652130.html

到了这里,关于使用PHP生成MySQL数据字典的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • PHP之 连接MySql数据库

    上一节已经成功配置了php+mysql开发环境( https://mp.csdn.net/mp_blog/creation/editor/129432310), 下面将进行实战连接数据库 一,打开sublime3编辑器,配置php开发环境 1.1 在网站根目录下新建php项目文件夹,存放php文件 1.2 安装Package Control,按下ctrl+shift+p,调出输入框输入Package Control,

    2024年02月02日
    浏览(59)
  • PHP读取mysql数据并显示在html界面

    上面一篇已经说完在Hbuilder中如何配置PHP环境,接下来看下如何读到数据库信息并显示在html界面上呢? 1、在XAMLL的MySQL一行点击Admin按钮,进入到PhpMyAdmin界面(注意,有的浏览器可能打不开或者页面乱了,多试几个浏览器,我用的谷歌是可以打开的)。 2、在phpMyAdmin创建数据

    2024年02月09日
    浏览(32)
  • PHP 房产网站系统Dreamweaver开发mysql数据库web结构php编程计算机网页项目

    一、源码特点     PHP 房产网站系统是一套完善的WEB设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 源码 https://download.csdn.net/download/qq_41221322/88233553 论文 https://download.csdn.net/download/qq_41221322/88233555 PHP 房产网站系统Drea

    2024年02月12日
    浏览(52)
  • 【PHP网页应用】MySQL数据库增删改查 基础版

    使用PHP编写一个简单的网页,实现对MySQL数据库的增删改和展示操作 页面实现在index.php,其中basic.php为没有css美化的原始人版本 函数实现在database.php 目录 功能基本实现版  CSS美化版 basicindex.php  index.php   database.php 代码讲解 我们来展示一下页面和操作示例。 运行网页,可

    2024年01月16日
    浏览(49)
  • php连接上mysql数据库该的配置方法

    用mysql官方的管理工具workbench: 打开导出界面后,下一步,选择csv格式,导出后excel就能打开了 如果你需要在程序代码中导出,需要找到对应代码的excel处理库。 如php 的 phpExcel( 最新版已更名为 phpoffice/phpspreadsheet) 要根据你当前服务器的php版本选择。 然后根据excel库的api编写

    2024年02月16日
    浏览(35)
  • Mysql Php 推送获取随机数据解决分页重复问题

    或许你已经看过很多博主写的文章,要不就是抄袭,要不就是给你一个下面的语句,随机是随机了,但是多来两页,你会发现前面出现的数据在第三页甚至第二页就出现了 这是因为rand()机制的问题,他每次都会打乱数据给你,然后你去取的时候0-10,11-20都有可能是同一个数据

    2024年02月06日
    浏览(45)
  • PHP教学资源管理系统Dreamweaver开发mysql数据库web结构php编程计算机网页

    一、源码特点     PHP 教学资源管理系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 源码 https://download.csdn.net/download/qq_41221322/88260480 论文 https://download.csdn.net/download/qq_41221322/88260482 二、功能介绍 前

    2024年02月10日
    浏览(51)
  • PHP NBA球迷俱乐部系统Dreamweaver开发mysql数据库web结构php编程计算机网页

    一、源码特点     PHP NBA球迷俱乐部系统是一套完善的web设计系统,对理解php编程开发语言有帮助,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 基于PHP的NBA球迷俱乐部 二、功能介绍 1、前台主要功能: 系统首页 网站介绍 网站新闻浏览 球迷注册 球队简介浏

    2024年02月09日
    浏览(53)
  • 前端注册登录页面数据库交互(h5+css+php+mysql+axios)

    一个登录注册界面,并使用前端数据库实现登陆注册功能  首先是index.html 直接在index.html里面写了用axios,实现注册和登录 效果图 登录注册滑动实现 script.js style.css 然后是登录和注册的php login.php register.php

    2024年02月11日
    浏览(42)
  • 傻瓜式教学Docker 使用docker compose部署 php nginx mysql

    首先你可以准备这个三个服务,也可以在docker compose 文件中 直接拉去指定镜像,这里演示的是镜像服务已经在本地安装好了,提供如下: PHP 日常用的扩展都有了应该, 这两个你也可以移到上面的RUN一同安装 Nginx Mysql 直接从官方镜像资源中拉去 这样你将产生三个镜像 下面开始利用

    2024年02月01日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包