データベースからすべての製品を表示する自動テーブルを作成したいと思いました。ここで、その名前をクリックして、製品の詳細全体を表示できます。そして、私の考えでは、別の .php ファイルに移動するのではなく、同じページにとどまり、すべての製品の複数の .php ファイルを作成して時間を無駄にしないようにするというものでした。問題は、製品をクリックするたびに、製品の情報がロードされないことです (ちなみに、唯一の詳細は説明です)。
エラー
致命的なエラー: タイプ mysqli_result のオブジェクトを C:\wamp\www\goldenrod\index.php の 56 行目で配列として使用できません
これはデータベース接続です:
<?php
//Database Connections
$dbc = mysqli_connect('localhost', 'root', '', 'lionsierra_db') or die("Cannot find specified server");
//Product Database
$db_products = "SELECT * FROM `products`";
$products = mysqli_query($dbc, $db_products);
?>
そして、これは関数です:
<?php
//View product
if(isset($_GET['view_product'])) {
while($product=mysqli_fetch_assoc($products)) {
$products['ID'] = $_GET['view_product'];
//Display a product
echo "<p><span>
<span style='font-weight:bold;'>" . $products['ID']['name'] . "</span><br/>
<span>$" . $products['ID']['price'] . "</span><br/>
<span>" . $products['ID']['category'] . "</span><br/>
<span>" . $products['ID']['description'] . "</span>
</p>";
}
}
//View all products
echo '<table width="600" border="1" cellpadding="1" cellspacing="1">
<tr>
<th>Name</th>
<th>Price</th>
<th>Category</th>
</tr>';
while($product=mysqli_fetch_assoc($products)) {
echo "<tr>
<td><a href='./index.php?view_product=" . $product['ID'] . "'>". $product['name'] . "</a></td>
<td>" . $product['price'] . "</td>
<td>" . $product['category'] . "</td>
</tr>";
$ID = $product['ID'];
}
?>
私はまだ PHP と SQL にかなり慣れていないので、助けていただければ幸いです。