PHP实现获取并生成数据库字典的方法
来源: 阅读:1403 次 日期:2016-08-25 14:42:55
温馨提示: 小编为您整理了“PHP实现获取并生成数据库字典的方法”,方便广大网友查阅!

本文实例讲述了PHP实现获取并生成数据库字典的方法。分享给大家供大家参考,具体如下:

名单

/**

* 生成mysql数据字典

*/

header("Content-type:text/html;charset=utf-8");

// 配置数据库

$database = array();

$database['DB_HOST'] = 'localhost';

$database['DB_NAME'] = 'test';

$database['DB_USER'] = 'root';

$database['DB_PWD'] = '';

$mysql_conn = @mysql_connect("{$database['DB_HOST']}", "{$database['DB_USER']}", "{$database['DB_PWD']}") or die("Mysql connect is error.");

mysql_select_db($database['DB_NAME'], $mysql_conn);

$result = mysql_query('show tables', $mysql_conn);

mysql_query("set names utf8");

// 取得所有表名

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['DB_NAME']}'";

$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['DB_NAME']}'";

$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 = '';

// 循环所有表

//print_r($tables);

foreach($tables as $k => $v)

{

$html .= '';

$html .= '

';

$html .= '

';

$html .= '';

foreach($v['COLUMN'] AS $f)

{

$html .= '

';

$html .= '

';

$html .= '

';

$html .= '

';

$html .= '

';

$html .= '

';

$html .= '

';

}

$html .= '

表名:' . $v['TABLE_NAME'] . ' ' . $v['TABLE_COMMENT'] . '
字段名数据类型默认值允许非空自动递增备注
' . $f['COLUMN_NAME'] . ' ' . $f['COLUMN_TYPE'] . ' ' . $f['COLUMN_DEFAULT'] . ' ' . $f['IS_NULLABLE'] . ' ' . ($f['EXTRA'] == 'auto_increment'?'是':' ') . ' ' . $f['COLUMN_COMMENT'] . '

';

}

/* 生成word */

//header ( "Content-type:application/vnd.ms-word" );

//header ( "Content-Disposition:attachment;filename={$database['DB_NAME']}数据字典.doc" );

/* 生成excel*/

//header ( "Content-type:application/vnd.ms-excel" );

//header ( "Content-Disposition:attachment;filename={$database['DB_NAME']}数据字典.xls" );

// 输出

echo '

自动生成数据字典

';

echo '

'.$database['DB_NAME'].'数据字典

';

echo '

生成时间:' . date('Y-m-d H:i:s') . '

';

echo $html;

echo '

总共:' . count($tables) . '个数据表

';

echo '

Baidu
map
';

?>

希望本文所述对大家PHP程序设计有所帮助。

更多信息请查看 网络编程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!

2026上岸·考公考编培训报班

  • 报班类型
  • 姓名
  • 手机号
  • 验证码
关于我们| 联系我们| 人才招聘| 网站声明| 网站帮助| 非正式的简要咨询| 简要咨询须知| 新媒体/短视频平台| 手机站点| 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65099533/13759567129 获取招聘考试信息及咨询关注公众号:
咨询QQ:1093837350(9:00—18:00) 版权所有:
云南网警报警专用图标
Baidu
map