首頁 >資料庫 >mysql教程 >為什麼'bindParam”因常數而失敗以及如何使用'bindValue”來代替?

為什麼'bindParam”因常數而失敗以及如何使用'bindValue”來代替?

Patricia Arquette
Patricia Arquette原創
2024-12-05 02:17:08844瀏覽

Why Does `bindParam` Fail with Constants and How Can I Use `bindValue` Instead?

解決使用帶有常數的 bindParam 時出現的「無法透過引用傳遞參數2”錯誤

在您的程式碼片段中,您遇到錯誤“Cannot當嘗試使用帶有常數值(例如,PDO::PARAM_NULL)的bindParam時,透過引用傳遞參數2” 。出現此錯誤的原因是,當您傳遞常數值時,bindParam 需要綁定一個變數。

要解決此問題,您需要使用bindValue 而不是bindParam。 bindValue 將值直接綁定到參數,而不是變數。這是修正後的程式碼:

try {
    $dbh = new PDO('mysql:dbname=' . DB . ';host=' . HOST, USER, PASS);
    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    $dbh->setAttribute(PDO::MYSQL_ATTR_INIT_COMMAND, "SET NAMES 'utf8'");
}
catch(PDOException $e)
{
    ...
}
$stmt = $dbh->prepare('INSERT INTO table(v1, v2, ...) VALUES(:v1, :v2, ...)');
$stmt->bindValue(':v1', null, PDO::PARAM_INT); // Using bindValue with null and explicit type

注意:您可能會想使用bindValue(':param', null, PDO::PARAM_NULL),但這種方法並不總是有效。相反,建議使用顯式類型,例如本例中的 PDO::PARAM_INT。

以上是為什麼'bindParam”因常數而失敗以及如何使用'bindValue”來代替?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn