ホームページ > バックエンド開発 > PHPチュートリアル > 「mysqli_stmt::bind_param() 参照が必要です」エラーを修正する方法?

「mysqli_stmt::bind_param() 参照が必要です」エラーを修正する方法?

Barbara Streisand
リリース: 2024-12-01 17:25:14
オリジナル
524 人が閲覧しました

How to Fix the

「mysqli binding_param() Expected a Reference」エラーの解決

「mysqli_stmt::bind_param() のパラメータ 3」エラーが発生した場合参照であることが期待されており、値が指定されています」というエラーは、$params 配列が正しくないことを示しますバインディング用に設定されています。これを解決するには、mysqli_stmt_bind_param() の要件を理解することが重要です。

mysqli_stmt_bind_param() はパラメーターが参照によって渡されることを期待しているため、エラーが発生します。ただし、$params 配列には、参照ではない値のコピーが含まれています。これを修正するには、次のメソッドを使用して $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;
}
ログイン後にコピー

$params 配列に値への参照が含まれたら、次のメソッドを使用してパラメータを正しくバインドできます。コード:

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), refValues($params)));
mysqli_stmt_execute($sql_stmt);
ログイン後にコピー

OOP:

$insert_stmt = $mysqli->prepare($query);
array_unshift($params, $param_type);
call_user_func_array(array($insert_stmt, 'bind_param'), refValues($params));
$insert_stmt->execute();
ログイン後にコピー

以上が「mysqli_stmt::bind_param() 参照が必要です」エラーを修正する方法?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート