重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍thinkphp5.0框架如何生成数据库字典,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
创新互联公司作为成都网站建设公司,专注网站建设、网站设计,有关成都定制网站方案、改版、费用等问题,行业涉及成都办公窗帘等多个领域,已为上千家企业服务,得到了客户的尊重与认可。
示例代码使用PHP框架:Thinkphp5.0
PHP代码:
/** * 生成数据库字典html * 可直接另存为再copy到word文档中使用 * * @return mixed */ public function dataDictionary() { $tables = Db::query('SHOW TABLE STATUS'); $table_list = array_map('array_change_key_case', $tables); $table_data = []; foreach ($table_list as $item) { $table_name = str_replace(config('database.prefix'),'',$item['name']); $table_fields = $this->showColumns($table_name); foreach ($table_fields as &$fieldItem) { $fieldItem['comment'] = $this->getDbColumnComment($table_name, $fieldItem['name']); } $table_data[] = [ 'table_name' => $item['name'], 'table_comment' => $item['comment'], 'table_fields' => $table_fields ]; } $this->assign('table_data', $table_data); return $this->fetch(''); } /** * 显示表结构信息 * * @param string $table * @return array */ private function showColumns($table){ $sql = 'SHOW COLUMNS FROM `'.config('database.prefix').$table.'`'; $result = Db::query($sql); if ($result === false) return array(); $array = array(); if (!empty($result)) { foreach ($result as $k=>$v) { $array[$v['Field']] = [ 'name' => $v['Field'], 'type' => $v['Type'], 'null' => $v['Null'], 'default' => $v['Default'], 'primary' => (strtolower($v['Key']) == 'pri'), 'autoinc' => (strtolower($v['Extra']) == 'auto_increment'), ]; } } return $array; } /** * 获取数据库字段注释 * * @param string $table_name 数据表名称(必须,不含前缀) * @param string|boolean $field 字段名称(默认获取全部字段,单个字段请输入字段名称) * @param string $table_schema 数据库名称(可选) * @return string */ private function getDbColumnComment($table_name = '', $field = true, $table_schema = ''){ // 接收参数 $database = config('database'); $table_schema = empty($table_schema) ? $database['database'] : $table_schema; $table_name = $database['prefix'] . $table_name; // 处理参数 $param = [ $table_name, $table_schema ]; // 字段 $columnName = ''; if($field !== true){ $param[] = $field; $columnName = "AND COLUMN_NAME = ?"; } // 查询结果 $result = Db::query("SELECT COLUMN_NAME as field,column_comment as comment FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = ? AND table_schema = ? $columnName", $param); if(empty($result) && $field !== true){ return $table_name . '表' . $field . '字段不存在'; } // 处理结果 foreach($result as $k => $v){ $data[$v['field']] = $v['comment']; if(strpos($v['comment'], '#*#') !== false){ $tmpArr = explode('#*#', $v['comment']); $data[$v['field']] = json_decode(end($tmpArr), true); } } // 字段注释格式不正确 if(empty($data)){ return $table_name . '表' . $field . '字段注释格式不正确'; } return count($data) == 1 ? reset($data) : $data; }
Html代码: 相关教程:HTML视频教程
快速生成数据库字典 {foreach $table_data as $tableInfo}{$tableInfo.table_name}(表注释:{$tableInfo.table_comment})
字段 | 类型 | 空 | 默认 | 注释 |
---|---|---|---|---|
{$field.name} | {$field.type} | {$field.null} | {$field.default} | {$field.comment} |
以上是thinkphp5.0框架如何生成数据库字典的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!