1

mysql クエリを作成し、結果をテーブルに表示しましたが、mysql テーブルのフィールドまたは列名をテーブル ヘッダーとして配置したいと考えています。複数のphpファイルでこれを行いたいのですが、forループを使用して共通フィールドによって互いに関連付けられたレコードを表示するため、少し複雑です。簡単な成績表はこちら

echo "<table border='1' width='85%' cellpadding='5' align='center'>\n";
while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
 echo "\t<tr align='center'>\n";
foreach ($line as $col_value) {
echo "\t\t<td align='center'>$col_value</td>\n";
}

 echo "<td align='center'><img src=./images/$col_value border='3' ></td>";

 echo "\t</tr>\n";
}
echo "</table>\n";

タグとmysql列名を取得する方法以外はどこにあるのかわかりません。私は mysql_field_names で何かを試しましたが、うまくいきませんでした。for ループを含む別のテーブルを次に示します。

$last_pattern = null;
echo "<table border='1' width='80%' cellpadding='5' align='center'>\n";
while ($line = mysql_fetch_array($result, MYSQL_ASSOC)) {
 $col_count = count($line) - 1; // Subtract 1 because image isn't in a column
if ($line['PatternName'] !== $last_pattern) {
if ($last_pattern !== null) {
  echo "<td><tr align='center'>\n";
}
echo "<tr align='center'>\n  ";
foreach ($line as $col_name => $col_value) {
  switch ($col_name) {
  case 'YarnImage':
    break;
  case 'PatternImage':
    echo "<td><image src='images/$col_value' /></td>";
    break;
  default:
    echo "<td>$col_value</td>";
  }
}
$last_pattern = $line['PatternName'];
echo "</tr>\n  <tr align='center'><td colspan='$col_count'>\n";
}
$yarn_image = $line['YarnImage'];
echo "<img src='images/$yarn_image' width='150' height='150' border='3'/>\n";
}
if ($last_image !== null) {
echo "</td></tr>";
}
4

2 に答える 2

2

最初の行を連想配列としてフェッチした後、 で列名を取得できますarray_keys($line)

非推奨の ext/mysql 関数の使用をやめ、ext/mysqli または pdo_mysql に切り替えることにした場合は、mysqli_stmt::result_metadata()またはPDOStatement::getColumnMeta()などの便利な関数を利用できます。

于 2012-12-08T23:47:21.450 に答える
0

<th>ループの上にforeach ($line as $col_name => $col_value)ループを追加してみてください

$col_number = 1; // add a counter
foreach ($line as $col_names => $col_values) {
    if ($col_number <= $col_count){  // check if counter is >= to $col_count
    echo "<th>$col_names</th>";}
    $col_number++;}  // increase counter by 1
foreach ($line as $col_name => $col_value) {
... //rest of you code

また、コードの 7 行目に無効なテーブル要素があります -

  echo "<td><tr align='center'>\n";
于 2012-12-08T23:46:33.523 に答える