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

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

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

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

Q&A

解決済

3回答

30800閲覧

SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of

退会済みユーザー

退会済みユーザー

総合スコア0

MySQL

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

0グッド

0クリップ

投稿2016/10/03 04:53

編集2016/10/03 06:24

###前提・実現したいこと
PHP5.6 + MySQL5.6でWebサイトを作成しています。
開発環境でテストしたモジュールを
検証環境にデプロイしたところ
バインド変数を指定するSQLでエラーが発生しました。

###発生している問題・エラーメッセージ

Error: SQLSTATE[HY093]: Invalid parameter number: number of bound variables does not match number of tokens

バインド変数が一致しないエラーが発生しています。
エラーとなるのは以下の×の場合です。
×のコードでも開発環境では動いていました。

sql

1 2// バインド変数2個 指定したパラーメータ2個 3select * from tableA where id = :id and date1 = :date 4params('id' => '100','date' => '2015/06/21') 5 6// バインド変数3個 指定したパラメータ2個 7select * from tableA where id = :id and date1 = :date and date2 = :date 8params('id' => '100','date' => '2015/06/21') 9 10// バインド変数に使用した値が使われていない(下の場合はName) 11× select * from tableA where id = :id and date = :date 12params('id' => '100','date' => '2015/06/21','name' => 'hoge') 13 14 15

###試したこと
my.cnfを開発環境に合わせる

###補足情報(言語/FW/ツール等のバージョンなど)
開発環境と検証環境でphpのバージョンが異なります。
開発環境:php5.5
検証環境:php5.6

しかし、5.5→5.6で本事象が発生したということは聞かず。。。
MySQLまたはPDOの設定が違うのでは無いかと
調査しております。

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

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

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

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

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

guest

回答3

0

自己解決しました
[原因]
PHPのバージョンが5.6のため
5.5 → 5.6でバインド変数のルールが厳しくなった?
5.5では以下のパラメタ指定でも動いていたが、5.6ではエラーになる。

// バインド変数に使用した値が使われていない(下の場合はName)
× select * from tableA where id = :id and date = :date
params('id' => '100','date' => '2015/06/21','name' => 'hoge')

[対応方法]
phpのバージョンを5.5にする
または、アプリケーションを修正する。

回答いただきましたyambejpさん
ありがとうございました。

投稿2016/10/03 06:39

編集2016/10/03 07:25
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

ベストアンサー

自己解決しました
[原因]
PHPのバージョンが5.6のため
5.5 → 5.6でバインド変数のルールが厳しくなった?
5.5では以下のパラメタ指定でも動いていたが、5.6ではエラーになる。

// バインド変数に使用した値が使われていない(下の場合はName)
× select * from tableA where id = :id and date = :date
params('id' => '100','date' => '2015/06/21','name' => 'hoge')

[対応方法]
phpのバージョンを5.5にする
または、アプリケーションを修正する。

回答いただきましたyambejpさん
ありがとうございました。

投稿2016/10/03 06:39

編集2016/10/03 06:41
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

PDOでの処理ですよね?ATTR_EMULATE_PREPARESの設定次第

静的プレースホルダを処理する場合、パラメータは再利用できません

PHP

1 $pdo = new PDO( 2 'mysql:host=localhost;dbname=test;charset=utf8', 3 'ユーザー名', 4 'パスワード', 5 array( 6 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, 7 PDO::ATTR_EMULATE_PREPARES => true,//falseが静的処理 8 ) 9 ) 10

というように動的プレースホルダーにするかそれぞれ別の名前で
パラメータを渡してあげてください

投稿2016/10/03 05:18

yambejp

総合スコア114779

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

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

退会済みユーザー

退会済みユーザー

2016/10/03 06:36

回答ありがとうございます。 PDO::ATTR_EMULATE_PREPARES => true を追加しましたが、エラーは変わりませんでした。
yambejp

2016/10/03 07:07

すみません、ちょっと読み違えてました。 過不足なくparamを与えて上げていなかったのですね 原則必要十分にパラメータは渡してください
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問