###前提・実現したいこと
mysqlで構築したデータベースから数字で検索をかけ、表示された検索結果をクリックして詳細情報を表示させるサイトを作りたいと思っています。
mysqlへの接続と検索結果の表示は成功しましたが、以下問題点と不明点があります。
①検索欄に何も表示しなくても検索が成功する。
②何が入力されていても全件の検索結果が表示される。
③詳細情報を表示するコードの書き方がわからない。
④可能ならば、ページを移動せずに同じ画面内に検索結果と詳細情報を表示させたい。
超初心者につき不明点も多いため、無茶苦茶なコードかもしれません。
お力添えを頂ければ幸いです。
###該当のソースコード
index.html
<!DOCUTYPE html> <html> <head> <meta http-equiv="content-type" content="text/thml;charset=utf-8"> <title>入力画面</title> </head> <body> <!--検索ページ構成--> <h1>入力画面</h1> <form name="freeserch" action="freeserch.php" method="post"> 番号:<input type="int" name="number"> <input type="submit" value="検索"> </form> </body> </html>
freesearch.php
<HTML> <HEAD> <TITLE>検索結果</TITLE> </HEAD> <BODY> <?php header('Content-Type: text/html; charset=UTF-8'); $db_user = "root"; $db_pass = "password"; $db_host = "localhost"; $db_name = "test"; $db_type = "mysql"; $dsn="$db_type:host=$db_host;dbname=$db_name;charset=utf8"; try { $pdo = new PDO($dsn,$db_user,$db_pass); $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION); $pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES,false); print"接続に成功しました...<br>"; } catch (PDOException $Exception) { die('エラー:'.$Exception->getMessage()); } //入力画面からのpostからデータを受け取る// $number = $_POST['number']; try { $sql="SELECT * FROM test WHERE number "; $stmh = $pdo->prepare($sql); $stmh->bindValue(':number', $sy,PDO::PARAM_STR); $stmh->execute(); $count = $stmh->rowCount(); print"検索結果は".$count."件です。<BR>"; } catch (PDOException $Exception) { print"エラー:".$Exception->getMessage(); } if ($count<1) { print"検索結果がありません。<BR>"; }else{ ?> <TABLE width="300" border="1" cellspacing="0" cellpadding="8"> <TBODY> <TR><th>番号</th><th>名前</th><th>値段</th></TR> <?php while ($row = $stmh->fetch(PDO::FETCH_ASSOC)) { ?> <TR> <td align="center"><?=htmlspecialchars($row['number'])?></td> <td><?=htmlspecialchars($row['name'])?></td> <td align="center"><?=htmlspecialchars($row['price'])?></td> </TR> <?php } ?> </TBODY></TABLE> <?php } ?> </BODY> </HTML>
###試したこと
詳細情報をmysqlから引っ張る為に、別にphpでコードを作る必要があるとの情報を見つけ、以下コードを上記freeserch.phpに入力しましたが、受け取る側のコードをどのように書けば良いかわかりません。
freesearch.php
<form action="syosai.php" method="POST" input type="hidden" name="key" value="<?=htmlspecialchars($row['number'])?>"><input type="submit" value="表示">
###補足情報(言語/FW/ツール等のバージョンなど)
PHP Version 7.1.6
関係ないかもしれませんが、xamppを使っています。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2017/07/09 09:54
2017/07/09 10:14 編集
2017/07/09 10:13 編集
2017/07/09 10:20
2017/07/09 10:23 編集
2017/07/09 10:24
2017/07/11 13:45