質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

3回答

4106閲覧

PHP,MySQL SELECTメニューで列名を取得して、その列に1が記載されている行を抽出して一覧表示したい

RyoUY

総合スコア29

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2016/02/10 14:56

###実現したいこと
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を使っています。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

自己解決

何が問題だったのかわかりませんが、もう一度ゼロから書き直してみたら、動きました。
アドバイスいただいたのに、原因がわからず、申し訳ありません。。

PHP

1<?php 2if(isset($_GET['key'])){ 3 $key = $_GET['key']; 4 try { 5 $PDO = new PDO('mysql:host=localhost;dbname=test;charset=utf8','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 function h($str) { 16 return htmlspecialchars($str, ENT_QUOTES, 'UTF-8'); 17 } 18} 19?> 20 21<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 22 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 23<html> 24<head> 25 <meta http-equive="Content-Type" content="text/html; charset=utf-8"> 26 <title>PHP Test</title> 27 <form method="GET" action="test.php"> 28 <select name="key"> 29 <option value="carrot">にんじん</option> 30 <option value="pumpkin">かぼちゃ</option> 31 <input type="submit" value="検索" /> 32 </select> 33</head> 34<body> 35<?php 36if(isset($key)){ 37echo $rows; 38}?> 39</body> 40</html>

投稿2016/02/11 11:39

RyoUY

総合スコア29

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

$key = $_GET['key']; //追加
if(isset($key)){

keyのチェックが1で行われていますが、submitで送られてくる値はselect optionのvalueになります。
carrotかpumpkinのいずれかですね。
もしカラムの値がindex化されているようでしたらこれらのvalueをindex値に変換する必要があります。
推測での対処になってしまいますがindex値ではなくvalueの値そのままがカラムに収められていると想定すると以下のようになります。(カラム名が'key'も本来の名前に置き換えて下さい)

$plans = $PDO->query("SELECT menu FROM table WHERE '$key' = 1");

$plans = $PDO->query("SELECT menu FROM table WHERE 'key' = {$key}");

投稿2016/02/10 19:41

piyoon

総合スコア68

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

piyoon

2016/02/10 19:48

$plans = $PDO->query("SELECT menu FROM table WHERE 'key' = {$key}"); ↓ $plans = $PDO->query("SELECT menu FROM table WHERE 'key' = '{$key}'"); シングルクォーテーションが抜けてました。
guest

0

isset($key) ↓ isset($_GET['key'])
SELECT menu FROM table WHERE '$key' = 1 ↓ SELECT menu FROM table WHERE カラムの名前(keyとか) = 1

投稿2016/02/10 17:42

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問