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

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

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

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

PHP

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

Q&A

3回答

726閲覧

検索フォームについて(複数のフィールドから検索できるようにしたいです)

aaaaaaaaa

総合スコア8

MySQL

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

PHP

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

0グッド

0クリップ

投稿2018/03/11 11:57

編集2018/03/12 01:43

人の名前や電話番号や性別という複数のフィールドから検索し、表示できるようにしたいのですが(例:検索フォームに男と打ったら検索結果に人の名前と電話番号と性別が出てくる等にしたいです)
エラー文にこう出てきます
「Warning: PDOStatement::bindValue() expects at most 3 parameters, 5 given in /○○○/○○○/○○○/○○○/○○○/search.php on line 28」と
「Warning: PDOStatement::execute(): SQLSTATE[HY093]: Invalid parameter number: no parameters were bound in /○○○/○○○/○○○/○○○/○○○/search.php on line 30」というエラーは色々調べた結果出なくなったのですが「検索失敗しました。」と出てきます
教えてくださったら助かります
よろしくお願い致します

コードがこちらです

hitoがテーブル名です
name,tel,sexがフィールド名(名前、電話番号、性別)です

<?php header("Content-type: text/html; charset=utf-8"); if(empty($_POST)) { header("Location: search.html"); exit(); }else{ //名前入力判定 if (!isset($_POST['yourname']) || $_POST['yourname'] === "" ){ $errors['hito'] = "入力されていません。"; } } if(count($errors) === 0){ $dsn = 'mysql:host=○○○';'dbname=○○○;charset=utf8'; $user = '○○○'; $password = '○○○'; try{ $dbh = new PDO($dsn, $user, $password); $statement = $dbh->prepare("SELECT * FROM hito where name LIKE (:name) and tel LIKE (:tel)"); if($statement){ $yourname = $_POST['yourname']; $like_yourname = "%".$yourname."%"; //プレースホルダへ実際の値を設定する $statement->bindValue(':name', $like_yourname, PDO::PARAM_STR); $statement->bindValue(':tel', $like_yourname, 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($yourname, ENT_QUOTES, 'UTF-8')."さんで検索しました。"?></p> <p><?=$row_count?>件です。</p> <table border='1'> <tr><td>名前</td><td>性別</td></tr> <?php foreach((array)$rows as $row){ ?> <tr> <td><?=$row['name,tel,sex']?></td> </tr> <?php } ?> <?php elseif(count($errors) > 0): ?> <?php foreach($errors as $value){ echo "<p>".$value."</p>"; } ?> <?php endif; ?> </body> </html>

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2018/03/11 12:02

エラーメッセージに書かれている通りなのに、何がわからないのでしょうか?
guest

回答3

0

全体的な流れとしてはこうするとよいでしょう

PHP

1<?PHP 2foreach(["name","tel","sex"] as $val){ 3 $$val=filter_input(INPUT_POST,$val); 4} 5 6$data=[]; 7$sql="SELECT * FROM hito where 1 "; 8if(is_null($name)){ 9 $sql.=" and 0 "; 10}else{ 11 foreach(["name","tel","sex"] as $val){ 12 if($$val!==""){ 13 $sql.="and {$val}=? "; 14 $data[]=$$val; 15 } 16 } 17} 18print $sql.";<br>"; 19print_r($data); 20/* 実際には以下のような処理 21 $stmt = $pdo->prepare($sql); 22 $stmt->execute($data); 23 $rows=$stmt->fetchAll(PDO::FETCH_ASSOC); 24 print_r($rows); 25*/ 26?> 27<form method="post"> 28<input type="text" name="name" placeholder="name"><br> 29<input type="text" name="tel" placeholder="tel"><br> 30<input type="text" name="sex" placeholder="sex"><br> 31<input type="submit" value="go"> 32</form> 33

投稿2018/03/12 01:01

yambejp

総合スコア114779

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

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

yambejp

2018/03/12 01:01

おそらくname,tel,sexのどれか入力されたものを使って and検索をしたいのだと思いますのでサンプルをあげておきました
guest

0

以下の部分でSQLが正しくないですね。
バインドもそうですけど、いきなりlikeで始まってますし。

php

1$statement = $dbh->prepare("SELECT * FROM hito where name = :name and tel = tel and sex = :sex LIKE (:name,:tel,:sex)");

投稿2018/03/11 12:06

sazi

総合スコア25173

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

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

aaaaaaaaa

2018/03/11 12:19

すみません、これをどう直せばいいでしょうか?質問だらけで申し訳ありません
sazi

2018/03/11 12:41

SQLが明らかにおかしかったので回答しましたが、すみませんPHPには詳しくないです。 抽出条件も単に(名前、電話番号、性別)のANDでいいなら、以下になります。 where name = :name and tel = :tel and sex = :sex ですが、バインド変数に値がうまく設定されているか良くわかりませんし、条件って可変じゃなくてよいのか?って気がします。
aaaaaaaaa

2018/03/11 13:21

ご回答ありがとうございます。自分の勉強不足なのでもっと勉強しようと思います ありがとうございました。
guest

0

Warning: PDOStatement::bindValue() expects at most 3 parameters, 5 given

PDOStatement :: bindValue()は最大で3つのパラメータが許可されていますが、5つ与えられています。(Google翻訳ほぼそのまま)

コードに行数がないので見た感じですが、エラーとなっているのは下記ですね。

php

1$statement->bindValue(':name',':tel',':sex', $like_yourname, PDO::PARAM_STR);

使い方間違ってます。

エラーメッセージは検索する癖をつけましょう。
Google翻訳にかければおおよそ意味は分かります。
そこからPHPマニュアルで機能の確認をすればほとんどのエラーは解決できます。

また、既に指摘されているようにSQLそのものも正しく組めていないので上記が解決したとしても想定通りには動かないと思いますので、指摘されている内容を参考にSQLも修正してください。

投稿2018/03/11 23:11

m.ts10806

総合スコア80850

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

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

退会済みユーザー

退会済みユーザー

2018/03/11 23:37

まあSQL、Bindをなおしても最低あと一つありますしね。
m.ts10806

2018/03/12 00:29

そこはなるべく本人に気づいてもらいたいところですね。 おそらくそこもエラーとなるので、「エラーがでたらまず検索」の習慣化の1歩目として。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問