用php显示mysql表

时间:2012-04-18 00:14:22

标签: php mysql

我在使用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 个答案:

答案 0 :(得分: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";
}

<强> 更新

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

enter image description here

答案 1 :(得分: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;

答案 2 :(得分:0)

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

答案 3 :(得分: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>';
}