用php生成数据字典
<?php
header("Content-type: text/html; charset=utf-8");
$dbserver = "localhost";
$dbusername="root";
$dbpassword="root";
$title = '数据字典';
if($_GET['db'] == ''){
$database = "aa";
}else{
$database = $_GET['db'];
} $mysql_conn = @mysql_connect("{$dbserver}","{$dbusername}","{$dbpassword}") or die("Mysql connect is error."); mysql_select_db($database,$mysql_conn);
$result = mysql_query('show tables',$mysql_conn);
mysql_query('SET NAMES utf8',$mysql_conn);
//取得所有表名
while($row = mysql_fetch_array($result)){
$tables[]['TABLE_NAME'] = $row[0];
}
//循环取得所有表的备注及表中列消息
foreach($tables as $k=>$v){
$sql = 'SELECT * FROM ';
$sql .= 'INFORMATION_SCHEMA.TABLES ';
$sql .= 'WHERE ';
$sql .= "table_name = '{$v['TABLE_NAME']}' AND table_schema = '{$database}'";
$table_result = mysql_query($sql,$mysql_conn);
while($t = mysql_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 = '{$database}'"; $fields = array();
$field_result = mysql_query($sql,$mysql_conn);
while($t = mysql_fetch_array($field_result)){
$fields[] = $t;
}
$tables[$k]['COLUMN'] = $fields;
}
mysql_close($mysql_conn); $html = '';
//循环所有表
foreach($tables as $k=>$v){
$html .='<table border="1" cellspacing="0" cellpadding="0" align="center">';
$html .='<caption>'.$v['TABLE_NAME'] .' '.$v['TABLE_COMMENT'] .'</caption>';
$html .='<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th><th>允许非空</th><th>自动递增</th><th>备注</th></tr>';
$html .=''; foreach($v['COLUMN'] AS $f){
$html .='<td class="c1">'.$f['COLUMN_NAME'].'</td>';
$html .='<td class="c2">'.$f['COLUMN_TYPE'].'</td>';
$html .='<td class="c3">'.$f['COLUMN_DEFAULT'].'</td>';
$html .='<td class="c4">'.$f['IS_NULLABLE'].'</td>';
$html .='<td class="c5">'.($f['EXTRA']=='auto_increment'?'是':' ').'</td>';
$html .='<td class="c6">'.$f['COLUMN_COMMENT'].'</td>';
$html .= '</tr>';
}
$html .='</tbody></table></p>';
}
echo '<html>
<meta charset="UTF-8">
<title>自动生成数据字典</title>
<style>
body,td,th {font-family:"宋体"; font-size:12px;}
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:26px; line-height:26px; font-size:12px; border:1px solid #CCC;}
table td{height:20px; font-size:12px; border:1px solid #CCC;background-color:#fff;}
.c1{ width: 120px;}
.c2{ width: 120px;}
.c3{ width: 70px;}
.c4{ width: 80px;}
.c5{ width: 80px;}
.c6{ width: 270px;}
</style>
<body>';
echo '<h1 style="text-align:center;">'.$title.'</h1>';
echo $html;
echo '</body></html>'; ?>
用php生成数据字典的更多相关文章
- 使用OpenXml实现生成数据字典文档(beta)
		最近项目在走验收流程,之前没有仔细看SOW文档,发现需要补好多份文档,其中就有数据字典,项目组不愿意花时间太多的时间弄这些文档,也不希望以后还要重复劳动力,最终决定做一个工具,方便自己生成数据字典文档 ... 
- php生成数据字典,代码
		<?php /** * 生成mysql数据字典 */ header("Content-type:text/html;charset=utf-8"); // 配置数据库 $da ... 
- 一条SQL生成数据字典
		有个字典表并定期维护,对DBA和开发很重要,终于把他们整合在一起了,看有没问题? 一条SQL生成数据字典,包含所有OPEN用户.表名.字段名.字段序号.字段属性.默认值.是否非空.字段意思.主键标识. ... 
- SQL server 生成数据字典
		Set nocount on ), ) DECLARE Tbls CURSOR FOR ),isnull(g.[value],'-')) AS TABLE_COMMENT FROM INFORMATI ... 
- 【PD】PowerDesigner生成数据字典
		1.首先说明我使用的环境 --------------------------------第一种:不按模板导出导出数据字典----------------------------- 2.打开PDM模型 ... 
- PHP连数据库生成数据字典
		<?php /** * 生成mysql数据字典 */ header("Content-type:text/html;charset=utf-8"); // 配置数据库 $da ... 
- mysql生成数据字典
		git clone https://github.com/twindb/undrop-for-innodb.git make [root@redis01 undrop-for-innodb]# mak ... 
- SQL Server 生成 数据字典 / 数据库文档
		1. 工具生成 2.SQL语句生成 参考地址:http://blog.csdn.net/qq289523052/article/details/22174721 1.在 表 上右键 - 扩展属性 - ... 
- PowerDesigner生成数据字典
		1.首先说明我使用的环境 2.打开PDM模型,右键-->NEW-->REPORT 3.数据字典编辑器(一些通用模型吧,自己可以再DIY) 4.选择Table-->List of Ta ... 
随机推荐
- HDU 4267 A Simple Problem with Integers --树状数组
			题意:给一个序列,操作1:给区间[a,b]中(i-a)%k==0的位置 i 的值都加上val 操作2:查询 i 位置的值 解法:树状数组记录更新值. 由 (i-a)%k == 0 得知 i%k == ... 
- JavaScript Promise API
			同步编程通常来说易于调试和维护,然而,异步编程通常能获得更好的性能和更大的灵活性.异步的最大特点是无需等待."Promises"渐渐成为JavaScript里最重要的一部分,大量的 ... 
- org.springframework.web.context.ContextLoaderListen 报错解决办法
			今天搭建SSH项目的时候出现了如下错误: 严重: Error configuring application listener of class org.springframework.web.con ... 
- mysql 存储过程,以及mybatis如何调用
			说道存储过程,很多人都知道,但是真正用的人其实很少,但是在某些必要的场景,是必须使用的,虽然可以使用java代码解决,但是效率性能远不及存储过程 曾经在sqlserver 以及pgadmin上用过,m ... 
- Could not publish server configuration for MyEclipse Tomcat v7.0. Multiple Contexts have a path
			Could not publish server configuration for Tomcat v6.0 Server at localhost. 经常在使用tomcat服务器的时候 总会发生一些 ... 
- f2fs解析(八)node 管理器中的node_info
			free_info 功成身退,node_info顺利接班. // 这里还是蛮复杂的一件事,如果不搞清除的话,这个历史性的接班工作我们就接不上 上面说到 alloc_nid 和 alloc_nid_do ... 
- Android开发eclipse运行程序时报timeout的解决方法
			eclipse开发Android程序时,忽然莫名其妙报这个错,之前还好好的.忽然就不行了. Failed to install xxx.apk on device~~~: timeout 尝试过手机里 ... 
- C语言 预处理二(宏定义--#define)
			//#define 宏定义(宏定义一般大写) //知识点一-->#define的作用域:从#define开始,从上往下,如果遇到#undef就到#undef处结束,如果没有就是作用于当前整个文件 ... 
- gunzip 和 unzip 解压文件到指定的目录
			Linux 常用的压缩命令有 gzip 和 zip,两种压缩包的结尾不同:zip 压缩的后文件是 *.zip ,而 gzip 压缩后的文件 *.gz 相应的解压缩命令则是 gunzip 和 unzi ... 
- 工作随笔——tar命令批量解压
			由于linux的tar命令不支持批量解压,所以很多网友编写了好多支持批量解压的shell命令,收集了一下,供大家分享: 第一: for tar in *.tar.gz; do tar xvf $tar ... 
