Heim  >  Artikel  >  Backend-Entwicklung  >  PHP-Implementierungsbeispiel zum Generieren einer Datenwörterbuchfunktion

PHP-Implementierungsbeispiel zum Generieren einer Datenwörterbuchfunktion

jacklove
jackloveOriginal
2018-06-22 15:48:181421Durchsuche

In diesem Artikel wird hauptsächlich die Funktion zum Generieren eines Datenwörterbuchs in PHP vorgestellt, einschließlich PHPs allgemeiner Verbindung, Datentabellenabfrage, Durchquerung, Tabellenzusammensetzung und anderen verwandten Betriebsfähigkeiten für MySQL

Das Beispiel in diesem Artikel beschreibt, wie PHP die Funktion zum Generieren eines Datenwörterbuchs implementiert. Ich teile es Ihnen als Referenz mit:

Ich bin in letzter Zeit unter Zeitdruck und habe keine Zeit, einen Blog zu veröffentlichen. Ich werde die Zeit nutzen, um einen Wissenspunkt mit Ihnen zu teilen Du. Bei der Entwicklung stoßen wir möglicherweise häufig auf das Problem, die Datenbank zu analysieren und ein Datenwörterbuch zu erstellen. Jetzt müssen Sie nur dem von mir gesendeten Link folgen, um das Datenwörterbuch einfacher zu gestalten Als Entwickler müssen Sie sich dieses Wissen mit nur wenigen Codezeilen aneignen. Schauen Sie sich also den folgenden Code an Geben Sie ein Datenbankkonto und ein Kennwort ein und führen Sie es dann aus.

Effektanzeige:

Nachdem ich so viel Unsinn geredet habe, habe ich endlich angefangen, Code zu schreiben:

<?php
/**
* 生成mysql数据字典
*/
//配置数据库
$dbserver  = "127.0.0.1";
$dbusername = "账号";
$dbpassword = "密码";
$database   = "数据库";
//其他配置
$title = &#39;数据字典&#39;;
$mysql_conn = @mysql_connect("$dbserver", "$dbusername", "$dbpassword") or die("Mysql connect is error.");
mysql_select_db($database, $mysql_conn);
mysql_query(&#39;SET NAMES utf8&#39;, $mysql_conn);
$table_result = mysql_query(&#39;show tables&#39;, $mysql_conn);
//取得所有的表名
while ($row = mysql_fetch_array($table_result)) {
   $tables[][&#39;TABLE_NAME&#39;] = $row[0];
}
//循环取得所有表的备注及表中列消息
foreach ($tables AS $k=>$v) {
   $sql = &#39;SELECT * FROM &#39;;
   $sql .= &#39;INFORMATION_SCHEMA.TABLES &#39;;
   $sql .= &#39;WHERE &#39;;
   $sql .= "table_name = &#39;{$v[&#39;TABLE_NAME&#39;]}&#39; AND table_schema = &#39;{$database}&#39;";
   $table_result = mysql_query($sql, $mysql_conn);
   while ($t = mysql_fetch_array($table_result) ) {
     $tables[$k][&#39;TABLE_COMMENT&#39;] = $t[&#39;TABLE_COMMENT&#39;];
   }
   $sql = &#39;SELECT * FROM &#39;;
   $sql .= &#39;INFORMATION_SCHEMA.COLUMNS &#39;;
   $sql .= &#39;WHERE &#39;;
   $sql .= "table_name = &#39;{$v[&#39;TABLE_NAME&#39;]}&#39; AND table_schema = &#39;{$database}&#39;";
   $fields = array();
   $field_result = mysql_query($sql, $mysql_conn);
   while ($t = mysql_fetch_array($field_result) ) {
     $fields[] = $t;
   }
   $tables[$k][&#39;COLUMN&#39;] = $fields;
}
mysql_close($mysql_conn);
$html = &#39;&#39;;
//循环所有表
foreach ($tables AS $k=>$v) {
   //$html .= &#39;<p><h2>&#39;. $v[&#39;TABLE_COMMENT&#39;] . &#39; </h2>&#39;;
   $html .= &#39;<table border="1" cellspacing="0" cellpadding="0" align="center">&#39;;
   $html .= &#39;<caption>&#39; . $v[&#39;TABLE_NAME&#39;] .&#39; &#39;. $v[&#39;TABLE_COMMENT&#39;]. &#39;</caption>&#39;;
   $html .= &#39;<tbody><tr><th>字段名</th><th>数据类型</th><th>默认值</th>
   <th>允许非空</th>
   <th>自动递增</th><th>备注</th></tr>&#39;;
   $html .= &#39;&#39;;
   foreach ($v[&#39;COLUMN&#39;] AS $f) {
     $html .= &#39;<tr><td class="c1">&#39; . $f[&#39;COLUMN_NAME&#39;] . &#39;</td>&#39;;
     $html .= &#39;<td class="c2">&#39; . $f[&#39;COLUMN_TYPE&#39;] . &#39;</td>&#39;;
     $html .= &#39;<td class="c3"> &#39; . $f[&#39;COLUMN_DEFAULT&#39;] . &#39;</td>&#39;;
     $html .= &#39;<td class="c4"> &#39; . $f[&#39;IS_NULLABLE&#39;] . &#39;</td>&#39;;
     $html .= &#39;<td class="c5">&#39; . ($f[&#39;EXTRA&#39;]==&#39;auto_increment&#39;?&#39;是&#39;:&#39; &#39;) . &#39;</td>&#39;;
     $html .= &#39;<td class="c6"> &#39; . $f[&#39;COLUMN_COMMENT&#39;] . &#39;</td>&#39;;
     $html .= &#39;</tr>&#39;;
   }
   $html .= &#39;</tbody></table></p>&#39;;
}
//输出
echo &#39;<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>&#39;.$title.&#39;</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>
</head>
<body>&#39;;
echo &#39;<h1 style="text-align:center;">&#39;.$title.&#39;</h1>&#39;;
echo $html;
echo &#39;</body></html>&#39;;
?>

Artikel, die Sie interessieren könnten:

Verwandte Erläuterungen zu grundlegenden Vorgängen der CodeIgniter-Framework-Datenbank

PHP-Methode zum Abrufen aller Daten dieser Woche oder aller Daten der letzten sieben Tage

Vergleich der Auswirkungen von PHP lcg_value und mt_rand, die 0~1 zufällige Dezimalstellen erzeugen

Das obige ist der detaillierte Inhalt vonPHP-Implementierungsbeispiel zum Generieren einer Datenwörterbuchfunktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn