>데이터 베이스 >MySQL 튜토리얼 >PDO에서 'SQLSTATE[HY093]: 잘못된 매개변수 번호'가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

PDO에서 'SQLSTATE[HY093]: 잘못된 매개변수 번호'가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-11 10:17:10440검색

Why Does PDO Throw

SQLSTATE[HY093]: PDO에 잘못된 매개변수 번호

함수를 실행하려고 하면 "SQLSTATE[HY093]"이라는 오류 메시지가 나타납니다. : 잘못된 매개변수 번호'가 나타날 수 있습니다. 이 문제는 PDO의 명명된 매개변수 동작에 대한 오해로 인해 발생합니다.

제공한 함수에는 다음 코드가 포함되어 있습니다.

$sql = "INSERT INTO persist (user_id, hash, expire) VALUES (:user_id, :hash, :expire) ON DUPLICATE KEY UPDATE hash=:hash";

SQL 문에 대해 명명된 매개변수를 정의할 때 각 고유 매개변수 표시문자가 한 번만 사용되도록 하는 것이 중요합니다. 그러나 이 경우 ":hash"가 두 번 사용되어 오류가 발생합니다.

이 문제를 해결하려면 PDOStatement를 호출할 때 문에 전달하는 각 값에 고유한 매개 변수 표시자를 할당해야 합니다. ::execute():

$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)
);

결과 SQL 쿼리는 잘못된 매개변수 번호를 만나지 않고 "지속" 테이블을 성공적으로 삽입하거나 업데이트합니다. 오류가 발생했습니다.

위 내용은 PDO에서 'SQLSTATE[HY093]: 잘못된 매개변수 번호'가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.