>백엔드 개발 >PHP 튜토리얼 >PHP에서 mysql 데이터 사전을 생성하는 방법

PHP에서 mysql 데이터 사전을 생성하는 방법

*文
*文원래의
2018-01-02 11:39:172101검색

MySQL 데이터베이스에서 데이터베이스 테이블과 필드를 보는 데 직접 사용할 수 있는 데이터 사전을 생성해야 합니다. 이 기사에서는 mysql 데이터 사전을 생성하기 위한 PHP 관련 정보를 주로 소개합니다. 관심 있는 친구들은 이를 참고할 수 있습니다. 그것이 모두에게 도움이 되기를 바랍니다.

아래 코드는 간단한 구성 변경만으로 사용이 가능하고, 스타일도 매우 좋습니다.

<?php 
header(&#39;content-type:text/html;charset=utf-8&#39;); 
define(&#39;DB_HOST&#39;,&#39;localhost&#39;); 
define(&#39;DB_USER&#39;,&#39;root&#39;); 
define(&#39;DB_PASS&#39;,&#39;root&#39;); 
define(&#39;DB_NAME&#39;,&#39;test&#39;); 
define(&#39;DB_PORT&#39;,3306); 
define(&#39;DB_CHAR&#39;,&#39;utf8&#39;); 
define(&#39;APPNAME&#39;,&#39;&#39;); 
$conn=mysql_connect(DB_HOST.&#39;:&#39;.DB_PORT,DB_USER,DB_PASS); 
mysql_select_db(DB_NAME); 
mysql_query(&#39;set names &#39; . DB_CHAR); 
$sql="SHOW TABLE STATUS FROM " . DB_NAME; 
$result=mysql_query($sql); 
$array=array(); 
while($rows=mysql_fetch_assoc($result)){ 
$array[]=$rows; 
} 
// table count 
$tab_count = count($array); 
echo &#39;<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="zh"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>&#39;.APPNAME.&#39;--数据字典</title> 
<style type="text/css"> 
  table caption, table th, table td { 
    padding: 0.1em 0.5em 0.1em 0.5em; 
    margin: 0.1em; 
    vertical-align: top; 
  } 
  th { 
    font-weight: bold; 
    color: black; 
    background: #D3DCE3; 
  } 
  table tr.odd th, .odd { 
    background: #E5E5E5; 
  } 
  table tr.even th, .even { 
    background: #f3f3f3; 
  } 
  .db_table{ 
    border-top:1px solid #333; 
  } 
  .title{font-weight:bold;} 
</style> 
</head> 
<body> 
<p style="text-align:center;background:#D3DCE3;font-size:19px;"> 
  <b>&#39;.APPNAME.&#39;--数据字典</b> 
</p> 
<p style="background:#f3f3f3;text-align:center;">(注:共&#39;.$tab_count.&#39;张表,按ctrl+F查找关键字)</p>&#39;."\n"; 
for($i=0;$i<$tab_count;$i++){ 
echo &#39;<ul type="square">&#39;."\n"; 
echo &#39; <li class="title">&#39;; 
echo ($i+1).&#39;、表名:[&#39; . $array[$i][&#39;Name&#39;] . &#39;]   注释:&#39; . $array[$i][&#39;Comment&#39;]; 
echo &#39;</li>&#39;."\n"; 
//查询数据库字段信息 
$tab_name = $array[$i][&#39;Name&#39;]; 
$sql_tab=&#39;show full fields from `&#39; . $array[$i][&#39;Name&#39;].&#39;`&#39;; 
$tab_result=mysql_query($sql_tab); 
$tab_array=array(); 
  
while($r=mysql_fetch_assoc($tab_result)){ 
  $tab_array[]=$r; 
} 
//show keys 
$keys_result=mysql_query("show keys from `".$array[$i][&#39;Name&#39;].&#39;`&#39;,$conn); 
$arr_keys=mysql_fetch_array($keys_result); 
  echo &#39;<li style="list-style: none outside none;"><table border="0" class="db_table" >&#39;; 
  echo &#39;<tr class="head"> 
    <th style="width:110px">字段</th> 
    <th>类型</th> 
    <th>为空</th> 
    <th>额外</th> 
    <th>默认</th> 
    <th style="width:95px">整理</th> 
    <th>备注</th></tr>&#39;; 
  for($j=0;$j<count($tab_array);$j++){ 
    $key_name=$arr_keys[&#39;Key_name&#39;]; 
    if($key_name="PRIMARY"){ 
      $key_name=&#39;主键(&#39;.$key_name.&#39;)&#39;; 
    } 
    $key_field=$arr_keys[&#39;Column_name&#39;]; 
    if ( $tab_array[$j][&#39;Field&#39;]==$key_field){ 
      $key_value="PK"; 
    }else{ 
      $key_value=""; 
    } 
    echo &#39;    <tr class="&#39;.($j%2==0?"odd":"even").&#39;">&#39;."\n"; 
    echo &#39;     <td>&#39; . $tab_array[$j][&#39;Field&#39;] . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . $tab_array[$j][&#39;Type&#39;] . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . ($key_value!=&#39;&#39;?$key_value:$tab_array[$j][&#39;Null&#39;]) . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . $tab_array[$j][&#39;Extra&#39;] . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . $tab_array[$j][&#39;Default&#39;] . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . $tab_array[$j][&#39;Collation&#39;] . &#39;</td>&#39;."\n"; 
    echo &#39;     <td>&#39; . ($key_value!=&#39;&#39;?$key_name:$tab_array[$j][&#39;Comment&#39;]) . &#39;</td>&#39;."\n"; 
    echo &#39;    </tr>&#39;."\n"; 
  } 
  echo &#39; </table></li>&#39;."\n"; 
  echo &#39;</ul>&#39;."\n"; 
  
} 
echo &#39;</body>&#39;."\n"; 
echo &#39;</html>&#39;."\n";

관련 권장 사항:

php mysql PDO 쿼리 작업 예제 소개

php mysqli 확장 전처리 예제 자세한 설명

php mysql 연결 주제: 가장 완벽한 PHP 연결 요약 mysql 데이터베이스 튜토리얼

위 내용은 PHP에서 mysql 데이터 사전을 생성하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.