2

我无法使用 php 代码显示我的 mysql 表。它显示的只是列名,而不是与它们关联的值。我知道我的用户名密码和数据库都是正确的,但就像我说的表格没有显示我添加的值。任何帮助将不胜感激这是我的mysql代码:

CREATE TABLE Guitars
(
  Brand  varchar(20)  NOT NULL,
  Model  varchar(20)  NOT NULL,
  PRIMARY KEY(Brand)
);

insert into Guitars values('Ibanez','RG');
insert into Guitars values('Ibanez','S');
insert into Guitars values('Gibson','Les Paul');
insert into Guitars values('Gibson','Explorer');

这是我的 php 代码:

<?php
$db_host = '*****';
$db_user = '*****';
$db_pwd = '*****';

$database = '*****';
$table = 'Guitars';

if (!mysql_connect($db_host, $db_user, $db_pwd))
    die("Can't connect to database");

if (!mysql_select_db($database))
    die("Can't select database");

// sending query
$result = mysql_query("SELECT * FROM {$table}");
if (!$result) {
    die("Query to show fields from table failed");
} 

$fields_num = mysql_num_fields($result);

echo "<table border='1'><tr>";
// printing table headers
for($i=0; $i<$fields_num; $i++)
{
    $field = mysql_fetch_field($result);
    echo "<td>{$field->name}</td>";
}
echo "</tr>\n";
// printing table rows
while($row = mysql_fetch_row($result))
{
    echo "<tr>";

    // $row is array... foreach( .. ) puts every element
    // of $row to $cell variable
     foreach($row as $cell)
        echo "<td>$cell</td>";

    echo "</tr>\n";
}
mysql_free_result($result);
?>
4

4 回答 4

4

试试这个:

// printing table rows
while($row = mysql_fetch_row($result))
{
    echo "<tr>";

    echo "<td>$row[0]</td>";
    echo "<td>$row[1]</td>";

    echo "</tr>\n";
}

更新:

注意:您不能将品牌作为主键,因为您将为不同的型号添加相同的品牌名称。

在此处输入图像描述

于 2012-04-18T00:27:00.220 回答
3

我不明白你为什么要使用这个fetch_field电话。我假设您在调用数据之前提前知道表中每个字段的实际名称是什么?我认为为简单起见(更少的循环和嵌套循环),您应该手动编写字段的名称,然后遍历输入值的数据。

$feedback .= "<table border='1'><tr>";
$feedback .= "<th>Brand</th><th>Model</th></tr>";

while ($row = mysql_fetch_array($result)) {
   $feedback .= "<tr><td>" . $row['Brand'] . "</td>";
   $feedback .= "<td>" . $row['Model'] . "</td></tr>";
}

$feedback .= "</table>";

echo $feedback;
于 2012-04-18T00:49:01.493 回答
0

当您完成显示标题时,查询结果的内部指针将到达最后一行,因此您的mysql_fetch_row()调用失败,因为没有更多行可获取。在打印表格行之前调用mysql_data_seek(0);,将内部指针移回第一行。

于 2012-04-18T00:21:26.463 回答
0

您也可以尝试获取数据

while ($fielddata = mysql_fetch_array($result))
{
    echo '<tr>';
    for ($i = 0; $i<$fields_num; $i++) // $fields_num already exists in your code
    {
        $field = mysql_fetch_field($result, $i);
        echo '<td>' . $fielddata[$field->name] . '</td>';
    }
    echo '</tr>';
}
于 2012-04-18T00:38:11.063 回答