使用PHP生成MySQL数据字典

发布时间:2019-10-09 09:22:22 阅读:8

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

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

    项目开始的比较急,最开始建数据库的时候没有用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']. ')'."\n";
                $html .= '  '."\n";
                $html .= '    '."\n";
              $html .= '      '."\n";
              $html .= '        字段名'."\n";
              $html .= '        数据类型'."\n";
              $html .= '        默认值'."\n";
              $html .= '        允许非空'."\n";
              $html .= '        自动递增'."\n";
              $html .= '        备注'."\n";
              $html .= '      '."\n";
           
                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 .= '      '."\n";
                  $html .= '        ' . $f['COLUMN_NAME'] . ''."\n";
                  $html .= '        ' . $f['COLUMN_TYPE'] . ''."\n";
                  $html .= '        ' . $f['COLUMN_DEFAULT'] . ''."\n";
                  $html .= '        ' . $f['IS_NULLABLE'] . ''."\n";
                  $html .= '        ' . ($f['EXTRA']=='auto_increment'?'是':' ') . ''."\n";
                  $html .= '        ' . $f['COLUMN_COMMENT'] . ''."\n";
                  $html .= '      '."\n";
                }
                }
                $html .= '    '."\n";
              $html .= '  '."\n";
            }
            return $html;
        }

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

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

     

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