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

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

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

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

Q&A

解決済

1回答

1700閲覧

PHPでmysqlから国名以外でも検索できるようにして、それに関連する情報を持ってきたい

dog57

総合スコア131

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

MySQL

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

PHP

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

データベース

データベースとは、データの集合体を指します。また、そのデータの集合体の共用を可能にするシステムの意味を含めます

0グッド

0クリップ

投稿2017/08/25 09:03

編集2017/08/25 09:06

###前提・実現したいこと
PHPで検索機能を実装しています。
データベースに一つでも引っかかるキーワードがあればそれに関連する情報を全て持ってくるようにしたいです。今の段階では国名で検索し、mysqlからデータを持ってくることには成功しています。

国名以外でもrank,food,reasonからでも検索ができるようにしたいです。

イメージ説明
イメージ説明
イメージ説明

###発生している問題・エラー
国以外の食べ物、順位、理由で検索しても引っ張って0件です。と出てしまいます。(上記の上から3つ目の画像)

###該当のソースコード

トップページ(検索画面)

html

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 5<meta charset="UTF-8"> 6<title>My Web Site</title> 7<link rel="stylesheet" href="style.css"> 8<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.4/jquery.min.js"> 9 10 </script> 11 12</head> 13<body> 14 15 16<header> 17 18 <div class="header-left"> 19 <img class="logo" src="https://www.fastpic.jp/images.php?file=3519571152.jpg" alt="ロゴ画像"> 20 </div> 21 22<div class="header-right"> 23 <a href="http://onepiece-naruto.com/blog-category-12.html" class="login" target="_blank"><p class="login1">ログイン</p></a> 24</div> 25 26 27</header> 28 29 30<div class="main"> 31 32 <h1>行ってみたい<span></span>一覧</h1> 33 <form class="research" action="search.php" method="post"> 34 <input class="research" size="40" type="text" name="nation" value="入力してください"> 35 <input class="research" type="submit" name="research" value="検索"><br> 36 <a href="index2.html"><input class="research" type="button" name="btn" value="新規登録"></a> 37 </form> 38 39 40</div> 41 42 43<div class="wrapper"> 44 45 46 47 <table border="1"> 48 49 <tr> 50 <th class="head">順位</th> 51 <th class="head">国名</th> 52 <th class="head">食べたい食べ物</th> 53 <th class="head">理由</th> 54 <th class="head"></th> 55 </tr> 56 57 58 <tr> 59 <td>1位</td> 60 <td>スペイン</td> 61 <td>パエリア</td> 62 <td>サッカーを見たいから</td> 63 <td><a href="update1.php">編集</a> <a href="#">削除</a></td> 64 </tr> 65 66 <tr> 67 <td>2位</td> 68 <td>アメリカ</td> 69 <td>グリルロブスター</td> 70 <td>ダンスの文化を知りたいから</td> 71 <td><a href="update1.php">編集</a> <a href="#">削除</a></td> 72 </tr> 73 74 <tr> 75 <td>3位</td> 76 <td>インド</td> 77 <td>カレーライス</td> 78 <td>発展途上の国を間近で見てみたいから</td> 79 <td><a href="update1.php">編集</a> <a href="#">削除</a></td> 80 </tr> 81 82 <tr> 83 <td>4位</td> 84 <td>タイ</td> 85 <td>ガパオ</td> 86 <td>バンコクの発展具合を見てみたいから</td> 87 <td><a href="update1.php">編集</a> <a href="#">削除</a></td> 88 </tr> 89 90 <tr> 91 <td>5位</td> 92 <td>フィリピン</td> 93 <td>アドボ </td> 94 <td>友達が楽しそうに働いているから</td> 95 <td><a href="update1.php">編集</a> <a href="#">削除</a></td> 96 </tr> 97 98 99 100 </table> 101 102</div> 103 104 105 106 107 108 109<footer> 110 111 112<div class="footer-left"> 113<img src="https://www.fastpic.jp/images.php?file=3519571152.jpg" alt="ロゴ画像"> 114<p>&copy travel enjoy.</p> 115</div> 116 117<div class="footer-list"> 118 <ul> 119 <li><a href="https://www.airbnb.jp/">利用規約</a></li> 120 <li><a href="https://www.uber.com/ja-JP/">プライバシー</a></li> 121 <li><a href="https://tabelog.com/tokyo/A1307/A130701/13191934/">アクセシビリティ</a></li> 122 </ul> 123</div> 124 125 126 127</footer> 128 129 <script src="script.js"> 130 131 </script> 132 133 134</body> 135</html> 136

検索結果画面

php

1<?php 2 3$nation = $_POST["nation"]; 4header("Content-type: text/html; charset=utf-8"); 5 6if(empty($_POST)) { 7 header("Location: search.php"); 8 exit(); 9}else{ 10 //国名入力判定 11 if (!isset($_POST['nation']) || $_POST['nation'] === "" ){ 12 $errors['country'] = "国名が入力されていません。"; 13 } 14} 15 16if(count($errors) === 0){ 17 18 $dsn = 'mysql:host=localhost;dbname=uriage;charset=utf8'; 19 $user = 'andrew'; 20 $password = 'andrew135'; 21 22 try{ 23 24 $dbh = new PDO($dsn, $user, $password); 25 $statement = $dbh->prepare('SELECT * FROM country WHERE nation LIKE :nation'); 26 27 28 29 30 if($statement){ 31 $nation = $_POST['nation']; 32 $like_nation = "%".$nation."%"; 33 34 //プレースホルダへ実際の値を設定する 35 $statement->bindValue(':nation', $like_nation, PDO::PARAM_STR); 36 37 38 39 if($statement->execute()){ 40 //レコード件数取得 41 $row_count = $statement->rowCount(); 42 43 while($row = $statement->fetch()){ 44 $rows[] = $row; 45 } 46 47 }else{ 48 $errors['error'] = "検索失敗しました。"; 49 } 50 51 //データベース接続切断 52 $pdo = null; 53 } 54 55 }catch (PDOException $e){ 56 print('Error:'.$e->getMessage()); 57 $errors['error'] = "データベース接続失敗しました。"; 58 } 59} 60 61?> 62 63<!DOCTYPE html> 64<html> 65<head> 66<title>検索結果</title> 67<meta charset="utf-8"> 68</head> 69<body> 70 71<?php if (count($errors) === 0): ?> 72 73<p><?=htmlspecialchars($nation, ENT_QUOTES, 'UTF-8')."で検索しました。"?></p> 74<p><?=$row_count?>件です。</p> 75 76<table border='1'> 77<tr><td>id</td> 78 <td>順位</td> 79 <td></td> 80 <td>食べたい食べ物</td> 81 <td>理由</td> 82</tr> 83 84<?php 85foreach($rows as $row){ 86?> 87<tr> 88 <td><?=$row['id']?></td> 89 <td><?=htmlspecialchars($row['rank'],ENT_QUOTES,'UTF-8')?></td> 90 <td><?=htmlspecialchars($row['nation'],ENT_QUOTES,'UTF-8')?></td> 91 <td><?=htmlspecialchars($row['food'],ENT_QUOTES,'UTF-8')?></td> 92 <td><?=htmlspecialchars($row['reason'],ENT_QUOTES,'UTF-8')?></td> 93</tr> 94<?php 95} 96?> 97 98<?php elseif(count($errors) > 0): ?> 99<?php 100foreach($errors as $value){ 101 echo "<p>".$value."</p>"; 102} 103?> 104<?php endif; ?> 105 106 107 108</body> 109</html> 110

###試したこと
課題に対してアプローチしたことを記載してください
select文を下記のように変更しましたが、ダメでした。

php

1$statement = $dbh->prepare('SELECT * FROM country WHERE nation LIKE :nation or rank like :rank 2 or food like :food 3 or reason like :reason');

###補足情報(言語/FW/ツール等のバージョンなど)
php5.6.30

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

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

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

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

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

guest

回答1

0

ベストアンサー

PHP

1$statement = $dbh->prepare('SELECT * FROM country WHERE nation LIKE :nation or rank like :rank 2 or food like :food 3 or reason like :reason')

としてますが、:rankや:food、:reasonの設定をしてないからではと思います。
:rankや:food、:reasonの設定をするかSQL文変えるとするならば

PHP

1$statement = $dbh->prepare('SELECT * FROM country WHERE nation LIKE :nation or rank like :nation or food like :nation or reason like :nation');

では

投稿2017/08/25 09:17

rururu3

総合スコア5545

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

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

dog57

2017/08/25 09:25

なるほど、ちなみに「:」はどういった役割を果たしているのでしょうか?調べても書いてあることがバラバラなのでしっくりきません。部分一致の役割でしょうか?
rururu3

2017/08/25 09:29

ざっくりいうと $statement->bindValue(':nation', $like_nation, PDO::PARAM_STR); によってSQL文にある':nationの部分を$like_nationに変えるって言う感じです。 書いてあることがバラバラなことはないと思いますが、 http://php.net/manual/ja/pdo.prepared-statements.php を見るのが一番確実でしょう。
dog57

2017/08/25 09:50

ありがとうございます!もう一つ質問なのですが、LIKEはLIKE検索(あいまい検索)という認識で大丈夫でしょうか?
dog57

2017/08/25 10:01

ありがとうございます。大変助かりました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問