web-dev-qa-db-ja.com

mysqli bind_param()は参照であることが期待され、値が指定されています

理解できません、エラーの原因は何ですかmysqli_stmt :: bind_param()のパラメータ3は参照であることが期待され、値は...

PDO
$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$param_type = "isss";
$sql_stmt = mysqli_prepare ($mysqli, $query);
call_user_func_array('mysqli_stmt_bind_param', array_merge(array($sql_stmt, $param_type), $params));
mysqli_stmt_execute($sql_stmt);

OOPも試しました

OOP
$insert_stmt = $mysqli->prepare($query);
array_unshift($params, $param_type);
call_user_func_array(array($insert_stmt, 'bind_param'), $params);
$insert_stmt->execute();

しかし、同じエラーですが、パラメーター2が問題を引き起こしているだけです。

では、$ paramsの何が問題になっていますか? $ paramsを値の配列にする必要があります。

24
woopata

[〜#〜]更新[〜#〜]

この回答は古くなっています。 Stackyが回答したような新しいPHPバージョンでは、spread演算子を使用してください。

Php docuから:

Mysqli_stmt_bind_param()をcall_user_func_array()と組み合わせて使用​​する場合は注意が必要です。 mysqli_stmt_bind_param()ではパラメーターを参照渡しする必要があるのに対し、call_user_func_array()ではパラメーターとして、参照または値を表すことができる変数のリストを受け入れることができます。

そして、ページ mysqli-stmt.bind-param には異なる解決策があります:

例えば:

call_user_func_array(array($stmt, 'bind_param'), refValues($params));

function refValues($arr){
    if (strnatcmp(phpversion(),'5.3') >= 0) //Reference is required for PHP 5.3+
    {
        $refs = array();
        foreach($arr as $key => $value)
            $refs[$key] = &$arr[$key];
        return $refs;
    }
    return $arr;
}
57
bitWorking

PHP 5.6で導入され、 ... operator ( "spread operator")を使用して、同じ結果をより少ないトラブルで実現します。

//object-oriented
$sql_stmt->bind_param($param_type, ...$params);

//procedural
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);
28
Stacky

DunnoがコードでWord 'PDO'を使用する理由はこれだけです。 [〜#〜] pdo [〜#〜] を使用し、mysqliの準備済みステートメントで発生する問題に直面しないでください。

$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$stmt = $pdo->prepare($query);
$stmt->execute($params);

このクリーンで簡潔なコードを見て、mysqliで準備したステートメントで必要なコードと比較してください。

1