###実現したいこと
PHP,MySQL(phpMyAdimin)でWEBサイトを作っています。
MySQLのデータベースは、横に「野菜」、縦に「メニュー」が記載されています。HTMLのセレクトメニューで野菜の種類を選ぶと、その野菜を使ったメニューがすべて出るようにしたいです。
エラー表示は出てきませんが、submitボタンを押してもなんの変化もありません。教えていただけないでしょうか。
(例)セレクトメニューで「ごぼう」を選ぶと、「きんぴら」と表示されるようにしたい。
にんじん ごぼう たまねぎ
カレー 1 1
きんぴら 1 1
###ソースコード
lang
1<?php 2header("Content-Type:text/html;charset=utf-8"); 3if(isset($key)){ 4 try { 5 $PDO = new PDO('mysql:host=localhost;dbname=test;charset=utf-8','root','root'); 6 $PDO->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 7 $rows = ""; 8 $plans = $PDO->query("SELECT menu FROM table WHERE '$key' = 1"); 9 while($result = $plans->fetch(PDO::FETCH_ASSOC)){ 10 $rows .= $result['menu']."</br>"; 11 } 12 } catch (PDOException $e) { 13 exit('接続エラー' . $e->getMessage()); 14 } 15} 16function h($str) { 17 return htmlspecialchars($str, ENT_QUOTES, 'UTF-8'); 18} 19?> 20 21 22<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 23 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 24<html> 25<head> 26 <meta http-equive="Content-Type" content="text/html; charset=utf-8"> 27 <title>PHP Test</title> 28</head> 29<body> 30 <a href="test.php">TOPページ</a><br /> 31 <form method="GET" action="test.php"> 32 <select name="key"> 33 <option value="carrot">にんじん</option> 34 <option value="pumpkin">かぼちゃ</option> 35 <input type="submit" value="検索" /> 36 </select> 37 <?php 38 if(isset($key)){ 39 echo $rows; 40 } 41 ?> 42</body> 43</html>
###補足情報
PHP7.0.0
MySQL 5.5.42
MACでMAMPを使っています。
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。