当前位置:首页 > PHP教程 > php高级应用 > 列表

PHP生成MySQL数据表结构程序代码

发布:smiling 来源: PHP粉丝网  添加日期:2015-04-15 14:55:05 浏览: 评论:0 

用过dedecms系统的朋友都会看到在后台的数据表管理中我们可以在后台看到表的数据表结构及字符长度了,下面我也整理了一个PHP生成MySQL数据字典数据表结构例子,大家一起来看看.

程序代码如下:

  1. <?php 
  2. /** 
  3.  * 生成mysql数据字典 
  4.  */ 
  5. // 配置数据库 
  6. $database = array(); 
  7. $database['DB_HOST'] = '127.0.0.1'
  8. $database['DB_NAME'] = 'test'
  9. $database['DB_USER'] = 'testuser'
  10. $database['DB_PWD'] = '123456'
  11.  
  12. $mysql_conn = @mysql_connect("{$database['DB_HOST']}""{$database['DB_USER']}""{$database['DB_PWD']}"or die("Mysql connect is error."); 
  13. mysql_select_db($database['DB_NAME'], $mysql_conn); 
  14. $result = mysql_query('show tables'$mysql_conn); 
  15. mysql_query('SET NAME GBK'$mysql_conn);  
  16. // 取得所有表名 
  17. while ($row = mysql_fetch_array($result)) 
  18.  $tables[]['TABLE_NAME'] = $row[0]; 
  19. }  
  20. // 循环取得所有表的备注及表中列消息 
  21. foreach($tables as $k => $v
  22.  $sql = 'SELECT * FROM '
  23.  $sql .= 'INFORMATION_SCHEMA.TABLES '
  24.  $sql .= 'WHERE '
  25.  $sql .= "table_name = '{$v['TABLE_NAME']}' AND table_schema = '{$database['DB_NAME']}'"
  26.  $table_result = mysql_query($sql$mysql_conn); 
  27.  while ($t = mysql_fetch_array($table_result)) 
  28.  { 
  29.   $tables[$k]['TABLE_COMMENT'] = $t['TABLE_COMMENT']; 
  30.  } 
  31.  $sql = 'SELECT * FROM '
  32.  $sql .= 'INFORMATION_SCHEMA.COLUMNS '
  33.  $sql .= 'WHERE '
  34.  $sql .= "table_name = '{$v['TABLE_NAME']}' AND table_schema = '{$database['DB_NAME']}'"
  35.  $fields = array(); 
  36.  $field_result = mysql_query($sql$mysql_conn); 
  37.  while ($t = mysql_fetch_array($field_result)) 
  38.  { 
  39.   $fields[] = $t
  40.  } 
  41.  $tables[$k]['COLUMN'] = $fields
  42. mysql_close($mysql_conn); 
  43. $html = '';  
  44. // 循环所有表 
  45. foreach($tables as $k => $v
  46.  $html .= '<table border="1" cellspacing="0" cellpadding="0" align="center">'
  47.  $html .= '<caption>表名:' . $v['TABLE_NAME'] . ' ' . $v['TABLE_COMMENT'] . '</caption>'
  48.  $html .= '<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th><th>允许非空</th><th>自动递增</th><th>备注</th></tr>'
  49.  $html .= ''
  50.  foreach($v['COLUMN'] AS $f
  51.  { 
  52.   $html .= '<td class="c1">' . $f['COLUMN_NAME'] . '</td>'
  53.   $html .= '<td class="c2">' . $f['COLUMN_TYPE'] . '</td>'
  54.   $html .= '<td class="c3">' . $f['COLUMN_DEFAULT'] . '</td>'
  55.   $html .= '<td class="c4">' . $f['IS_NULLABLE'] . '</td>'
  56.   $html .= '<td class="c5">' . ($f['EXTRA'] == 'auto_increment'?'是':' ') . '</td>';  //开源软件:phpfensi.com 
  57.   $html .= '<td class="c6">' . $f['COLUMN_COMMENT'] . '</td>'
  58.   $html .= '</tr>'
  59.  } 
  60.  $html .= '</tbody></table></p>'
  61. // 输出 
  62. echo '<html> 
  63.     <meta charset="utf-8"
  64.     <title>自动生成数据字典</title> 
  65.     <style> 
  66.         body,td,th {font-family:"宋体"; font-size:12px;}   
  67.   table,h1,p{width:960px;margin:0px auto;} 
  68.         table{border-collapse:collapse;border:1px solid #CCC;background:#efefef;}   
  69.         table caption{text-align:left; background-color:#fff; line-height:2em; font-size:14px; font-weight:bold; }   
  70.         table th{text-align:left; font-weight:bold;height:26px; line-height:26px; font-size:12px; border:1px solid #CCC;padding-left:5px;}   
  71.         table td{height:20px; font-size:12px; border:1px solid #CCC;background-color:#fff;padding-left:5px;}   
  72.         .c1{ width: 150px;}   
  73.         .c2{ width: 150px;}   
  74.         .c3{ width: 80px;}   
  75.         .c4{ width: 100px;}   
  76.         .c5{ width: 100px;}   
  77.         .c6{ width: 300px;} 
  78.     </style> 
  79.     <body>'; 
  80. echo '<h1 style="text-align:center;">数据字典</h1>'
  81. echo '<p style="text-align:center;margin:20px auto;">生成时间:' . date('Y-m-d H:i:s') . '</p>'
  82. echo $html
  83. echo '<p style="text-align:left;margin:20px auto;">总共:' . count($tables) . '个数据表</p>'
  84. echo '</body></html>'
  85. ?>

Tags: MySQL数据表结构 PHP生成MySQL

分享到: