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

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

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

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

Q&A

解決済

1回答

548閲覧

【php】データベース内検索から条件にあった結果を返す方法

mimi_01

総合スコア1

PHP

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

0グッド

0クリップ

投稿2021/06/21 05:55

編集2021/06/23 04:08

※以前の質問からすこし進んだため修正しました。

前提・実現したいこと

検索したとき「付いているタグ」に応じてイラストやリンクを返すコンテンツを作りたいです。

フォームはHTMLで以下のように作りました。

HTML

1<form id="MyForm" method="POST" action="action.php" autocomplete="off"> 2<div class="mainform"> 3<input id="input" name="word" maxlength="100" class="form-control form-control-lg mb-2" type="text" placeholder="ここに入力してください" value=""> 4</div> 5<input id="submit" type="submit" value="診断する"> 6</form>

データベースはMySQLで以下のように作りました。

id(番号)、name(テキスト)、category(テキスト)、tag(番号 1-10番まで)

入力されたword(検索ワード)でDB内のname(テキスト)が見つかった時にcategoryの文字とtagに応じたイラスト結果を返すようにしたいです。

こちらのファイルがaction.phpとなります。

<?php header("Content-type: text/html; charset=utf-8"); if(empty($_POST)) { header("Location: xxx"); exit(); }else{ if (!isset($_POST['word']) || $_POST['word'] === "" ){ $errors['name'] = "入力されていません。"; } } if(count($errors) === 0){ $dsn = 'mysql:host=localhost;dbname=data1;charset=utf8'; $user = 'root'; $password = 'root'; try{ $dbh = new PDO($dsn, $user, $password); $statement = $dbh->prepare("SELECT * FROM data1 WHERE name LIKE (:name) "); if($statement){ $word = $_POST['word']; $like_word= "%".$word."%"; //プレースホルダへ実際の値を設定する $statement->bindValue(':name', $like_word PDO::PARAM_STR); if($statement->execute()){ //レコード件数取得 $row_count = $statement->rowCount(); while($row = $statement->fetch()){ $rows[] = $row; } }else{ $errors['error'] = "検索失敗しました。"; } //データベース接続切断 $dbh = null; } }catch (PDOException $e){ print('Error:'.$e->getMessage()); $errors['error'] = "データベース接続失敗しました。"; } } ?> <!DOCTYPE html> <html> <head> <title>結果</title> <meta charset="utf-8"> </head> <body> <?php if (count($errors) === 0): ?> <p><?=htmlspecialchars($word, ENT_QUOTES, 'UTF-8')."で検索しました。"?></p> <p><?=$row_count?>件です。</p> <?php foreach($rows as $row){ ?> <table border='1'> <tr> <td>「<?=htmlspecialchars($row['name'],ENT_QUOTES,'UTF-8')."」は"?></td> </tr> <tr> <td><?=htmlspecialchars($row['category'],ENT_QUOTES,'UTF-8')."</br>がおすすめです"?></td> </tr> <?php } ?> <?php elseif(count($errors) > 0): ?> <?php foreach($errors as $value){ echo "<p>".$value."</p>"; } ?> <?php endif; ?> </body> </html>

この状態で、今データベースに接続してカテゴリー結果を返すというところまでできています。

参考にしたもの:https://noumenon-th.net/programming/2016/02/15/pdo_search/

解決したいこと

name から tag を引き出して結果を返すという部分がうまくいきません。

試したけど失敗したもの↓

$tag = ["result1"=>1,"result2"=>2,"result3"=>3,"result4"=>4,"result5"=>5]; if(array_key_exists("result1",$tag)){ echo $tag["result"].PHP_EOL; } if(in_array(1,$tag)){ echo "画像".PHP_EOL; } if(in_array(2,$tag)){ echo "画像".PHP_EOL; }

tag1の場合はechoでresult1を、tag2の場合はresult2を表示したいです。
echoで返ってくる結果はイラストやアニメーションを入れたいと考えています。

まだまだ未熟で手探りでやっていますが、お力を貸していただけると有難いです。
よろしくお願いいたします(><)

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

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

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

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

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

y_waiwai

2021/06/21 06:01

このままではコードが見づらいので、質門を編集し、<code>ボタンで、出てくる’’’の枠の中にコードを貼り付けてください
mimi_01

2021/06/21 06:25

ご指摘ありがとうございます。修正しましたm(_ _)m
m.ts10806

2021/06/21 06:37

この仕組みはWordPressはどう関係させるのでしょうか。
mimi_01

2021/06/21 12:00

コメントありがとうございます。フォームをWordpressで表示させる予定です。
m.ts10806

2021/06/21 12:02

表示させたところで、WordPressで扱うように機能をきちんと使わないと単に独立したものにしかならないと思いますが・・。 既存のプラグインでは実装できないものですか?
mimi_01

2021/06/21 12:49

プラグインもかなり探したのですが、フォーム入力→回答の表示はできても、フォームで条件分岐して回答を表示させるものが見つかりませんでした…。もしご存知でしたら教えて頂きたいですm(_ _)m
guest

回答1

0

ベストアンサー

idnamecategorytag
1東京人形焼き1
2大阪たこ焼き2
3愛知味噌カツ3
4広島広島焼き2
5北海道ホタテ4
6鹿児島黒豚5

テーブルの内容は上記のようなものだと推測します。

PHP

1foreach($rows as $row){ 2?> 3<table border='1'> 4<tr> 5 <td><?=htmlspecialchars($row['name'],ENT_QUOTES,'UTF-8')."」は"?></td> 6</tr> 7<tr> 8 <td><?=htmlspecialchars($row['category'],ENT_QUOTES,'UTF-8')."</br>がおすすめです"?></td> 9</tr> 10<?php 11 12//ここで「tag」を拾ってやればよいのではないでしょうか 13 14 15switch( $row['tag'] ){//tagの値で分岐 16 17//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 18case "1": 19//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 20 21$result = "result1用URL"; 22 23break; 24//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 25case "2": 26//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 27 28$result = "result2用URL"; 29 30break; 31//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 32case "3": 33//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 34 35$result = "result3用URL"; 36 37break; 38//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 39case "4": 40//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 41 42$result = "result4用URL"; 43 44break; 45//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 46case "5": 47//■□■□■□■□■□■□■□■□■□■□■□■□■□■ 48 49$result = "result5用URL"; 50 51break; 52 53} 54 55//画像の表示 56echo <<<EOM 57<img src="{$result}"> 58EOM; 59 60 61}

DBの内容を回しているところで画像表示もしてしまえばよいのではないでしょうか

投稿2021/06/23 04:50

編集2021/06/23 04:52
jinba

総合スコア310

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

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

mimi_01

2021/06/23 10:03 編集

ご回答ありがとうございます! 教えて頂いた内容で無事タグ取得を動かすことができましたm(_ _)m 知識不足で申し訳ないのですが…「DBの内容を回しているところで画像表示」とは具体的にどういう意味なのでしょうか?まだ理解しきれていない部分があり、よろしければご教授いただけると嬉しいです。 何卒よろしくお願いいたします。
jinba

2021/06/23 10:41

while($row = $statement->fetch()){ $rows[] = $row; } //↑の部分でDBの内容を一行ずつ「$rows」へ配列として格納しています //省略… ↓さきほど格納した配列を1行ずつ繰り返すという意味です foreach($rows as $row){//ここから↓ ?> <table border='1'> <tr> <td>「<?=htmlspecialchars($row['name'],ENT_QUOTES,'UTF-8')."」は"?></td> </tr> <tr> <td><?=htmlspecialchars($row['category'],ENT_QUOTES,'UTF-8')."</br>がおすすめです"?></td> </tr> <?php //なので繰り返し回してる箇所内で「tag」を取得しましょうという意味です echo <<<EOM {$row['id']}:idが表示されます<br> {$row['name']}:nameが表示されます<br> {$row['category']}:categoryが表示されます<br> {$row['tag']}:tagが表示されます<br> EOM; //↑をこの箇所に表示させれば理解が深まるかも }//↑ここまでDBから取得した配列を繰り返し取得している
mimi_01

2021/06/26 02:34

ようやく理解できました!! 本当にありがとうございます!!!!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問