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













