>> PHP入門トップに戻る
「PDO プリペアドステートメントの使い方」で説明しましたが、
パラメータに値をセットする際はbindValueメソッドを使っていました。
実はもう一つ似たような名前のメソッド「bindParam」メソッドがあるので、説明しておきたいと思います。
以下のようなテーブルを準備してください。
bindParamメソッドの第一引数と第三引数はbindValueの時と一緒です。
わからない人は「PDO プリペアドステートメントの使い方」を参照してください。
そして、第二引数にはパラメータにバインドする「変数」を指定します。
値をそのまま指定することはできません。変数である必要があります。
なぜなら、第二引数に変数を指定することによって、その変数が「参照として」パラメータにバインドされるからです。
つまり、一度bindParamで変数をバインドしてしまえば、以降は変数の中身を変えてexecuteメソッドを実行するだけで、パラメータを変化させながらクエリを実行できます。
一度結果を表示した後は変数の中身を変えて、executeを実行しているだけです。
変数の参照がバインドされてるので、execute実行時に自動で変数の値を見に行ってくれているというわけです。
以上が、bindValueとbindParamの違いです。
私は個人的に毎回値をセットしておいたほうが落ち着くので、bindValueを使ってます。
>> 【PDO selectでデータを取得、fetchAll、queryメソッド】に進む
>> PHP入門トップに戻る
PDO bindValueとbindParamの違い
パラメータに値をセットする際はbindValueメソッドを使っていました。
実はもう一つ似たような名前のメソッド「bindParam」メソッドがあるので、説明しておきたいと思います。
以下のようなテーブルを準備してください。
1 | mysql> select * from test; |
2 | +----+------+------+ |
3 | | id | num | name | |
4 | +----+------+------+ |
5 | | 1 | 1 | AAA | |
6 | | 2 | 10 | BBB | |
7 | | 3 | 100 | CCC | |
8 | | 4 | 1000 | DDD | |
9 | +----+------+------+ |
わからない人は「PDO プリペアドステートメントの使い方」を参照してください。
そして、第二引数にはパラメータにバインドする「変数」を指定します。
値をそのまま指定することはできません。変数である必要があります。
なぜなら、第二引数に変数を指定することによって、その変数が「参照として」パラメータにバインドされるからです。
つまり、一度bindParamで変数をバインドしてしまえば、以降は変数の中身を変えてexecuteメソッドを実行するだけで、パラメータを変化させながらクエリを実行できます。
01 | //PDOオブジェクトの生成 |
02 | $pdo = new PDO( "mysql:dbname=test;host=localhost" ,USERNAME,PASSWORD); |
03 | //コロンと名前を使ったクエリの場合 |
04 | $stmt = $pdo ->prepare( "select name from test where id = :id and num = :num" ); |
05 |
06 | //セットする変数を定義 |
07 | $val = 2; |
08 | $val2 = 10; |
09 |
10 | //第二引数に変数をセットする |
11 | $stmt ->bindParam( "id" , $val ); |
12 | $stmt ->bindParam( "num" , $val2 ); |
13 | //結果表示 |
14 | $stmt ->execute(); |
15 | $result = $stmt ->fetch(); |
16 | echo "name = " . $result [ 'name' ].PHP_EOL; |
17 |
18 |
19 | //以降は変数の中身を変えてexecuteを実行するだけなので |
20 | $val = 3; |
21 | $val2 = 100; |
22 |
23 | //結果表示 |
24 | $stmt ->execute(); |
25 | $result = $stmt ->fetch(); |
26 | echo "name = " . $result [ 'name' ].PHP_EOL; |
変数の参照がバインドされてるので、execute実行時に自動で変数の値を見に行ってくれているというわけです。
以上が、bindValueとbindParamの違いです。
私は個人的に毎回値をセットしておいたほうが落ち着くので、bindValueを使ってます。
>> 【PDO selectでデータを取得、fetchAll、queryメソッド】に進む
>> PHP入門トップに戻る