現在PHP学習中です。
mysqlからデータを取得して表示したいのですが、1つのカラムしか表示されません。
アドバイスをください。
・問題のサイトはこちら
・PHPファイルの内容
<head> <title>試作品</title> <meta charset="utf-8"> </head> <body> <?php //データベース接続 $server = "●●●"; $userName = "●●●"; $password = "●●●"; $dbName = "●●●"; $mysqli = new mysqli($server, $userName, $password,$dbName); if ($mysqli->connect_error){ echo $mysqli->connect_error; exit(); }else{ $mysqli->set_charset("utf-8"); } if (array_key_exists($_POST, 'cat')) { // catパラメータを受信している if ((isset($_POST['cat'])) && (is_numeric($_POST['cat']))) { // catパラメータにアクセス可能で、数字として扱える文字列である $sql = "SELECT * FROM goods_table WHEER cat = ?"; $stmt = $mysqli->prepare("SELECT * FROM goods_table WHERE cat = ?"); $stmt->bindParam("i", $_POST['cat']); $stmt->execute(); $result = $stmt->get_result(); } } else { $sql = "SELECT * FROM goods_table"; $result = $mysqli->query($sql); } //クエリー失敗 if(!$result) { echo $mysqli->error; exit(); } //レコード件数 $row_count = $result->num_rows; //連想配列で取得 while($row = $result->fetch_array(MYSQLI_ASSOC)){ $rows[] = $row; } //結果セットを解放 $result->free(); // データベース切断 $mysqli->close(); ?> <p>商品名</p> <form action="uketoru.php" method="get"> <select name="syouhinmei"> <option value="kora">コーラ</option> <option value="mausu">マウス</option> <option value="biru">ビール</option> </select> </form> <br><br> <p>価格</p> <form action="どっかの住所" method="get"> <select name="kakaku"> <option value="100">100</option> <option value="200">200</option> <option value="300">300</option> </select> <br><br> <input type="submit" value="検索" /> </form> <h1>テーブル</h1> レコード件数:<?php echo $row_count; ?> <table border='1'> <tr><th>id</th><th>name</th></tr> <?php foreach($rows as $row){ ?> <tr> <td><?php echo $row['id']; ?></td> <td><?php echo htmlspecialchars($row['name'],ENT_QUOTES,'UTF-8'); ?></td> </tr> <?php } ?> </table> </body> </html>
else { $sql = "SELECT * FROM goods_table"; $result = $mysqli->query($sql);
を
else { $sql = "SELECT goods_id,name,price FROM goods_table"; $result = $mysqli->query($sql); }
にしてもできませんでした。
回答5件
あなたの回答
tips
プレビュー