Rumah >pangkalan data >tutorial mysql >Mengapa Penyata PHP PDO Saya Disediakan Membuang 'SQLSTATE[HY093]: Nombor Parameter Tidak Sah'?

Mengapa Penyata PHP PDO Saya Disediakan Membuang 'SQLSTATE[HY093]: Nombor Parameter Tidak Sah'?

Patricia Arquette
Patricia Arquetteasal
2024-12-16 08:48:16863semak imbas

Why Does My PHP PDO Prepared Statement Throw

PHP PDOException: "SQLSTATE[HY093]: Nombor Parameter Tidak Sah"

Menyahpepijat PHP PDOException boleh mencabar, terutamanya apabila menghadapi "SQLSTATE[HY093]: Nombor parameter tidak sah" kesilapan. Ralat ini selalunya menunjukkan penggunaan parameter yang dinamakan yang salah dalam pernyataan yang disediakan.

Pertimbangkan kod PHP berikut:

function add_persist($db, $user_id) {
    $hash = md5("per11".$user_id."sist11".time());
    $future = time()+(60*60*24*14);
    $sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash";
    $stm = $db->prepare($sql);
    $stm->execute(array(":user_id" => $user_id, ":hash" => $hash, ":expire" => $future));
    return $hash;
}

Apabila melaksanakan fungsi ini, ralat "SQLSTATE[HY093]: Tidak sah nombor parameter" mungkin berlaku. Punca utama terletak pada baris di mana kaedah execute() dipanggil. Khususnya, klausa ON DUPLICATE KEY UPDATE hash=:hash menggunakan nama parameter yang sama, ":hash", untuk kedua-dua operasi sisipan dan kemas kini.

Untuk menyelesaikan isu ini, anda perlu memberikan nama parameter unik untuk nilai cincang dalam klausa kemas kini. Berikut ialah kod yang diperbetulkan:

$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash2";
$stm->execute(
    array(":user_id" => $user_id, 
          ":hash" => $hash, 
          ":expire" => $future,
          ":hash2" => $hash)
);

Dengan memberikan nama parameter unik, ":hash2", untuk nilai cincang dalam klausa kemas kini, anda menyelesaikan ralat "SQLSTATE[HY093]: Nombor parameter tidak sah". Ini memastikan bahawa pemacu PDO boleh memetakan parameter dengan betul kepada pernyataan SQL yang disediakan.

Atas ialah kandungan terperinci Mengapa Penyata PHP PDO Saya Disediakan Membuang 'SQLSTATE[HY093]: Nombor Parameter Tidak Sah'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn