```php
<?php
/**
* 生成html数据字典
*/
$db = new DBdic("106.12.198.212","un_jipinlantu_co", "un_jipinlantu_co", "E7YhH8DZJGpfdb8A");
// $db1 =$db->outForBrowserWithMenu();
$db2 = $db->outForBrowser();
class DBdic
{
public $database = array(); //数据库配置
public $tables = array(); //读取的表信息数组
public $htmlTable = ''; //表格内容
public $html = '';
public $exportTables = array(); // 要导出的表
public $menu = array(); //左侧表名的菜单
public static function ini($host, $dbname, $user, $pwd)
{
return new self($host, $dbname, $user, $pwd);
}
function __construct($host, $dbname, $user, $pwd)
{
// 配置数据库
$this->database['DB_HOST'] = $host;
$this->database['DB_NAME'] = $dbname;
$this->database['DB_USER'] = $user;
$this->database['DB_PWD'] = $pwd;
}
public function build()
{
//链接MySQL
$mysqli = mysqli_init();
$mysqli->options(MYSQLI_OPT_CONNECT_TIMEOUT, 2); //超时2s
$mysqli->options(MYSQLI_INIT_COMMAND, "set names utf8mb4;");
$mysqli->real_connect($this->database['DB_HOST'], $this->database['DB_USER'], $this->database['DB_PWD'], $this->database['DB_NAME']) or die("Mysql connect is error.");
// 取得所有表名
$rs = $mysqli->query('show tables');
$arrTableName = array_column($rs->fetch_all(), $value=0);
// 取得所有表信息
foreach ($arrTableName as $name) {
$isExport = $this->isNeedExport($name);
if (!$isExport) {
continue;
}
//表注释
$sql = "select * from information_schema.tables where table_schema = '{$this->database['DB_NAME']}' and table_name = '{$name}' "; //查询表信息
$rs = $mysqli->query($sql);
$arrTableInfo = $rs->fetch_assoc();
//各字段信息
$sql = "select * from information_schema.columns where table_schema ='{$this->database['DB_NAME']}' and table_name = '{$name}' "; //查询字段信息
$rs = $mysqli->query($sql);
$arrColumnInfo = $rs->fetch_all(MYSQLI_ASSOC);
//索引信息
$sql = "show index from {$name}";
$rs = $mysqli->query($sql);
if (!empty($rs->num_rows)) {
$arrIndexInfo = $rs->fetch_all(MYSQLI_ASSOC);
} else {
$arrIndexInfo = array();
}
$this->tables[] = array(
'TABLE' => $arrTableInfo,
'COLUMN' => $arrColumnInfo,
'INDEX' => $this->getIndexInfo($arrIndexInfo)
);
}
//组装HTML
$html = '';
foreach($this->tables as $k => $v)
{
//左侧菜单信息
$this->menu[$k] = $v['TABLE']['TABLE_NAME'];
//主要内容
$html .= '<table align="center">';
$html .= '<caption id="menu_'.$k.'"><h3>' . $v['TABLE']['TABLE_NAME'] . ' ' . $v['TABLE']['TABLE_COMMENT'] . '</h3></caption>';
$html .= '<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th><th>允许非空</th><th>索引/自增</th><th>备注(字段数: '. count($v['COLUMN']).')</th></tr>';
foreach ($v['COLUMN'] AS $f) {
$html .= '<tr>'.PHP_EOL;
$html .= '<td class="c1">' . $f['COLUMN_NAME'] . '</td>'.PHP_EOL;
$html .= '<td class="c2">' . $f['COLUMN_TYPE'] . '</td>'.PHP_EOL;
$html .= '<td class="c3">' . $f['COLUMN_DEFAULT'] . '</td>'.PHP_EOL;
$html .= '<td class="c4">' . $f['IS_NULLABLE'] . '</td>'.PHP_EOL;
$html .= '<td class="c5">' . $f['COLUMN_KEY'].' '.$f['EXTRA']. '</td>'.PHP_EOL;
$html .= '<td class="c6">' . $f['COLUMN_COMMENT'] . '</td>'.PHP_EOL;
$html .= '</tr>'.PHP_EOL;
}
if (!empty($v['INDEX'])) {
$html .= '<tr><th colspan="2">索引名</th><th colspan="4">索引顺序</th></tr>';
foreach ($v['INDEX'] as $indexName => $indexContent) {
$html .= '<tr>'.PHP_EOL;
$html .= '<td class="c7" colspan="2">' . $indexName . '</td>'.PHP_EOL;
$html .= '<td class="c8" colspan="4">' . implode(' > ', $indexContent) . '</td>'.PHP_EOL;
$html .= '</tr>'.PHP_EOL;
}
}
$html .= '</tbody></table><br>'.PHP_EOL;
}
$this->htmlTable = $html;
return $this;
}
//设置需要导出的表, 参数为单个表
function setExportTable($tableName)
{
$this->exportTables[] = $tableName;
return $this;
}
//设置需要导出的表, 参数为数组
function setExportTableArray($arrTableName)
{
$this->exportTables = $arrTableName;
return $this;
}
public function isNeedExport($tname)
{
//判断当前表是否要导出
$isExport = TRUE;
if (!empty($this->exportTables)) {
if (in_array($tname, $this->exportTables)) {
//当前表在导出列表中
$isExport = TRUE;
} else {
$isExport = FALSE;
//正则匹配
foreach ($this->exportTables as $tableName) {
if (strpos($tableName, '*') !== FALSE ||
strpos($tableName, '+') !== FALSE ||
strpos($tableName, '\\') !== FALSE ||
strpos($tableName, '[') !== FALSE ||
strpos($tableName, '(') !== FALSE ||
strpos($tableName, '{') !== FALSE
) {
if (preg_match("/$tableName/", $tname, $matches) == 1) {
$isExport = TRUE;
break;
}
}
}
}
}
return $isExport;
}
//整合单个表的所有索引(将复合索引归纳到一起)
function getIndexInfo($arrIndexInfo)
{
$index = array();
foreach ($arrIndexInfo as $v) {
$unique = ($v['Non_unique'] == 0) ? '(unique)' : '';
// $index[$v['Key_name']][] = $v['Seq_in_index'].': '.$v['Column_name'].$unique;
$index[$v['Key_name']][] = $v['Column_name'].$unique;
}
return $index;
}
function getHtmlMenu()
{
$html = '<div id="menu"><ul>';
foreach ($this->menu as $k => $v) {
$id = 'menu_'.$k;
$html .= '<li><a href="#'.$id.'">'.$v.'</a></li>';
}
$html .= '</ul></div>';
return $html;
}
//输出到浏览器, 左侧有目录
function outForBrowserWithMenu()
{
$this->build();
header("Content-type:text/html;charset=utf-8");
$html = '<html>
<meta charset="utf-8">
<title>'.$this->database['DB_NAME'].'数据字典</title>
<style>
::-webkit-scrollbar {display:none}
header {display: block; width: 90%; align-content: center}
#menu {float: left; width: 20%; height: 2000px; overflow-y: scroll}
a:link,a:visited {color:#000;text-decoration:none;}
#content {float: left; width: 70%; height: 2000px; overflow-y: scroll}
table { width: 90%; font-family: Consolas,verdana,arial; font-size:14px; color:#333333; border-width: 1px; border-color: #ddd; border-collapse: collapse; margin-bottom: 5px; }
table caption { text-align:left; }
table caption h3 {margin:5px}
table th { border-width: 1px; padding: 8px; border-style: solid; border-color: #ddd; background-color: #f8f8f8; }
table td { border-width: 1px; padding: 8px; border-style: solid; border-color: #ddd; background-color: #ffffff; }
tr:hover td{ background-color:#f1f5fb; }
</style>
<body>';
$html .= '<header><h1 style="text-align:center;">'.$this->database['DB_NAME'].'数据字典</h1>';
$html .= '<p style="text-align:center;margin:20px auto;">生成时间:' . date('Y-m-d H:i:s') . ' 总共:' . count($this->tables) . '个数据表</p></header>';
$html .= $this->getHtmlMenu();
$html .= '<div id="content">'.$this->htmlTable.'</div>';
$html .= '</body></html>';
echo $html;
// return $this;
}
//输出到浏览器, 表格宽度用百分比
function outForBrowser()
{
$this->build();
header("Content-type:text/html;charset=utf-8");
$html = '<html>
<meta charset="utf-8">
<title>'.$this->database['DB_NAME'].'数据字典</title>
<style>
table { width: 50%; font-family: Consolas,verdana,arial; font-size:14px; color:#333333; border-width: 1px; border-color: #ddd; border-collapse: collapse; margin-bottom: 5px; }
table caption { text-align:left; }
table caption h3 {margin:5px}
table th { border-width: 1px; padding: 8px; border-style: solid; border-color: #ddd; background-color: #f8f8f8; }
table td { border-width: 1px; padding: 8px; border-style: solid; border-color: #ddd; background-color: #ffffff; }
tr:hover td{ background-color:#f1f5fb; }
</style>
<body>';
$html .= '<h1 style="text-align:center;">'.$this->database['DB_NAME'].'数据字典</h1>';
$html .= '<p style="text-align:center;margin:20px auto;">生成时间:' . date('Y-m-d H:i:s') . ' 总共:' . count($this->tables) . '个数据表</p>';
$html .= $this->htmlTable;
$html .= '</body></html>';
$this->html = $html;
echo $html;
// return $this;
}
//输出到word文档, 固定宽度为720px
function outForWord()
{
$this->build();
/* 下载word */
header("Content-type:text/html;charset=utf-8");
header("Content-type: application/octet-stream");
header("Accept-Ranges: bytes");
header("Content-type:application/vnd.ms-word" );
header('Cache-Control: max-age=0');
header("Content-Disposition:attachment;filename={$this->database['DB_NAME']}数据字典.docx" );
$html = '<html xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns="http://www.w3.org/TR/REC-html40">
<head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/></head>
<title>'.$this->database['DB_NAME'].'数据字典</title>
<style>
body,td,th {font-family:"宋体"; font-size:14px;}
table,h1,p{width:720px;margin:0px auto;}
table{border-collapse:collapse;border:1px solid #CCC;background:#efefef;}
table caption{text-align:left; background-color:#fff; line-height:2em; font-size:14px; font-weight:bold; }
table th{text-align:left; font-weight:bold;height:20px; line-height:20px; font-size:11px; border:1px solid #CCC;padding-left:5px;}
table td{height:20px; font-size:11px; border:1px solid #CCC;background-color:#fff;padding-left:5px;}
.c1{ width: 100px;}
.c2{ width: 110px;}
.c3{ width: 50px;}
.c4{ width: 55px;}
.c5{ width: 100px;}
.c6{ width: 300px;}
.c7{ width: 200px;}
.c8{ width: 515px;}
</style>
<body>';
$html .= '<h1 style="text-align:center;">'.$this->database['DB_NAME'].'数据字典</h1>';
$html .= '<p style="text-align:center;margin:20px auto;">生成时间:' . date('Y-m-d H:i:s') . ' 总共:' . count($this->tables) . '个数据表</p>';
$html .= $this->htmlTable;
$html .= '</body></html>';
$this->html = $html;
echo $html;
// return $this;
}
function out()
{
// echo $this->html;
}
}
```
- 服务器购买到搭建宝塔
- 结构规范
- php基础
- php简介
- php是什么
- PHP 能做什么
- PHP 如何运行
- 如何了解弱语言
- 安装环境
- 安装LNMP
- 宝塔
- phpstudy
- PHP基本语法
- PHP 标记
- 从 HTML 中分离
- 指令分隔符
- 注释
- php 数据类型
- 类型检测
- 四种标量类型
- boolean(布尔型)
- Integer 整型
- Float 浮点型
- String 字符串类型
- 两种复合类型
- array(数组)
- object(对象)
- 两种特殊类型
- resource(资源)
- NULL(无类型)
- 类型转换
- 变量
- 变量定义和命名规范
- 传值和引用
- 预定义变量
- php预定义变量
- $_SERVER详解
- 变量范围
- 全局变量
- 静态变量
- 可变变量
- 常量
- 常量简介
- 常量定义
- 相比变量
- 魔术常量
- 运算符
- 运算符简介
- 算术运算符
- 赋值运算符
- 位运算符
- 比较运算符
- 错误控制运算符
- 执行运算符
- 递增(减)运算符
- 逻辑运算符
- 字符串运算符
- 数组运算符
- 新增操作符
- 控制结构
- 控制简介
- if 语句
- while 语句
- for 语句
- foreach 语句
- break 语句
- continue 语句
- switch 语句
- declare 语句
- return 语句
- include 语句
- PHP 函数
- 函数简介
- 用户自定义函数
- 函数的参数
- 返回值
- 可变函数
- 内部函数
- 匿名函数
- PHP 的类和对象
- PHP 的类和对象简介
- 基本概念
- 对象继承
- 属性
- 类常量
- 自动加载对象
- 构造和析构函数
- 访问控制
- 范围解析操作符(::)
- 静态static
- Static 关键字
- 抽象类
- 接口
- 匿名类
- 面向对象其他特性
- const关键字
- final关键字
- abstract用于定义抽象方法和抽象类。
- self、$this、parent::关键字
- 接口(interface)
- trait关键字
- instanceof关键字
- 魔术方法
- 构造函数和析构函数
- 私有属性的设置获取
- __toString()方法
- __clone()方法
- __call()方法
- 类的自动加载
- 会话控制
- cookie
- PHP 操作 cookie
- 项目实战
- SESSION
- Session 的初步介绍与实验准备
- PHP 操作 session
- 项目实战2
- http
- 特点
- 工作过程
- request
- response
- HTTP状态码
- URL
- GET和POST的区别
- HTTPS
- 常用函数
- 常用的字符串函数
- 常用的数组函数
- 常用文件函数
- 常用时间函数
- 常用日历函数
- 常用url函数
- 面试题常见
- 时间戳
- 技术类文档
- 技术开发文档
- 开发环境
- 开发规范
- 注释规范
- 开发目录结构
- 数据库字典
- 路由
- 定时任务
- 获取系统配置
- 系统常用函数
- 后台表单
- 消息队列
- 第三方类库标注
- 需求文档
- 数据库
- MYSQL
- 事务(重点)
- 索引
- 存储过程
- 触发器
- 视图
- 导入导出数据库
- 优化mysql数据库的方法
- MyISAM与InnoDB区别
- 外连接、内连接的区别
- 物理文件结构
- MongoDB
- Redis
- 运用场景和实例
- pgsql
- 服务器
- Nginx
- 正向代理和反向代理
- 负载均衡
- Linux常用命令
- 基本目录和命令
- php开发工具
- phpStorm编辑器
- 安装和汉化
- 链接ftp
- 常用操作
- 常用快捷键
- 自定义快捷键
- 使用快捷键新建目录和文件
- 使用快捷键快速查找文件、类、方法
- 多文件切换
- 快速搜索设置项
- 多点编辑
- 方法重构
- 自定义文件模板和代码片段
- 自定义文件模板
- 自定义代码片段
- Xdebug 调试插件
- 安装Xdebug 调试插件
- 在PHPStorm 中使用 Xdebug 插件调试代码
- Vi Box虚拟机
- Vi Box 虚拟机 Oracle VM VirtualBox
- 虚拟机辅助工具一-Vagrant
- 华硕主板BIOS设置中VT虚拟化技术选项怎么开启 Oracle VM VirtualBox
- 沟通工具
- 文档分享
- 流程图
- 任务分配
- 代码托管
- 缺陷管理
- 设计图
- gitLab
- 安装
- 汉化
- Gitlab 用户和项目管理
- Gitlab 持续集成与自动构建实践
- PHP进阶
- 大流量解决方案
- PSR规范
- RESTFUL规范
- 设计模式
- 单例模式
- 策略模式
- 工厂模式
- 简单工厂模式
- 工厂方法模式
- 抽象工厂模式
- 外观模式
- 享元模式
- 代理模式
- 命令模式
- 中介者模式
- 观察者模式
- 状态模式
- 建筑者模式
- 适配器模式
- 桥接模式
- 装饰器模式
- 排序算法
- 冒泡排序算法
- 二分查找算法
- 直接插入排序算法
- 希尔排序算法
- 选择排序算法
- 快速排序算法
- 常见网络攻击类型
- CSRF攻击
- XSS攻击
- SQL注入
- Cookie攻击
- thinkphp
- thinkphp5命令行
- git
- Git 常用命令操作和基础学习
- 傻瓜与白痴的笔记本
- 学习
- 一、Git 与 GitHub 的来历
- 二、在 GitHub 上创建仓库
- 三、安装
- Windows 上安装 Git
- 安装2
- 四、克隆 GitHub 上的仓库到本地
- 五、GIT基本操作哦
- 六、Git 分支操作
- 一、添加SSH关联授权
- 二、为 Git 命令设置别名
- 三、Git 分支管理
- 七、多人协作 GitHub 部分
- 八、多人协作 Git 部分
- 九、Git tag 和 GitHub releases
- composer
- Composer 基础使用
- 安装和使用
- 在项目中集成PHPmailer
- 认识composer.json和composer.lock文件
- composer的其他命令操作
- 本地创建composer包
- 提交自己的依赖包到composer Packagist
- crontab计划任务
- Linux任务计划crontab
- php 的 计划任务——Crontab
- bootstrap前端框架
- 入门
- 实战技巧
- 后台模板样式——admin
- 第三方接口对接
- 微信
- 敏感词过滤
- 微信图片检测
- 短信类型
- 阿里云短信
- 容联云短信
- 飞鸽短信
- 媒体
- 新闻接口测试
- 免费新闻
- 免费视频
- nba赛事,未测试
- 豆瓣电影接口
- 音乐接口
- 网易短视频接口
- 知乎微信接口
- 百度ai
- 百度语音
- 图片识别
- 腾讯
- 腾讯im
- 腾讯云直播
- 腾讯滑动验证
- 物流快递
- 快递鸟、快递100
- 推送
- 极光推送
- 地图&天气
- 获取城市和天气预报
- 地址获取和定位
- 地址转换经纬度
- 图片类型
- 360新闻图片
- 多平台翻译
- 实名认证
- 七牛云
- 云合同
- 多站点收录查询接口
- 打印机
- 第三方登录
- 微信登录
- 支付
- 支付宝app支付
- 微信提现+退款
- 微信app支付
- 微信支付公式
- 类库
- 图片类
- phpqrcode实战:生成二维码
- 图片处理类
- 验证码类
- 消息类
- PHPMailer
- 分词类
- ik
- PHPAnalysis
- 自己封装的方法
- GD库
- 自动获取图片主题颜色
- 图片转素描
- 生成海报
- 图片转字符
- 验证码
- 图片转黑白灰
- GD库实现图片水印与缩略图
- Imagick扩展
- 将一张image图片转化为字符串的形式
- 基本方法
- 图片路径转base64
- 生成文件后缀图片
- url路径判断拼接
- 防篡改入口文件
- php中文姓名判断
- 可控抽奖
- 特殊截取
- 银行卡位(特殊卡号不支持)
- 微信红包计算
- 数组和对象互转
- php批量更新修改数据库
- base64_img上传
- 删库删目录————跑路
- 字符串特殊符号过滤
- 首字母转成默认头像
- 生成随机字符串
- 根据id转 邀请码
- 日志写入
- 字符串截取,超出显示省略号
- 清除html标签+清除html标签,字符串截取
- 计算时间差的函数和演示
- php判断路径是否是绝对路径,如果不是拼接至绝对路径
- sql 参数过滤
- php敏感词过滤
- 省市区分别截取
- 生成csv
- 无限极分类
- api接口返回封装的方法函数
- xml和数组互转
- 获取thinkph5下控制器和方法名
- 过滤
- 获取服务器信息
- php随机颜色
- 创建多级目录
- 推广码
- 跨域检测
- 二维码
- 文档类
- word
- PHPWord
- tcPdf
- MPDF
- dompdf
- FPDF、Fpdi类库
- excel
- PhpSpreadsheet导入
- phpExcel
- 时间
- PHP-农历+节气+节日等类库
- 时间类库
- 最好用的是人性化时间差
- 文件管理类
- 文件操作类
- 文件夹操作
- php操作ftp的类库
- curl
- 数据库操作类
- Db扩展函数
- 数据库备份
- 仿tp5的Db库
- 不常用mysql
- 自动生成数据库字典
- 字符串
- 字符串操作helper/Str
- 随机生成姓名
- 随机生成类
- php字符串类
- 中文转拼音的类库
- 分类
- 缓存
- 数据验证
- 身份证相关操作
- 安全类
- 表单生成类
- 自动生成表单,未完待续中