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
Lepaskan: 2024-12-16 08:48:16
asal
861 orang telah melayarinya

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;
}
Salin selepas log masuk

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)
);
Salin selepas log masuk

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!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan