>백엔드 개발 >PHP 튜토리얼 >업데이트 쿼리 후 PDO가 성공 대신 \'SQLSTATE[HY000]\'을 반환하는 이유는 무엇입니까?

업데이트 쿼리 후 PDO가 성공 대신 \'SQLSTATE[HY000]\'을 반환하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-22 23:05:29995검색

Why Does PDO Return

PDO 업데이트 오류: "SQLSTATE[HY000]" 이해

PDO를 사용하여 데이터베이스를 업데이트하려고 하면 "SQLSTATE[HY000]: 일반 오류" 오류가 발생할 수 있습니다. 반환됩니다. 보고된 오류에도 불구하고 데이터베이스가 성공적으로 업데이트되었기 때문에 이 오류는 혼란스러워 보일 수 있습니다.

오류 원인

이 오류의 근본 원인은 업데이트 또는 삽입 쿼리 후 fetchAll() 메서드. PDO의 fetchAll() 메소드는 일반적으로 선택 쿼리의 영향을 받는 모든 행을 검색하는 데 사용됩니다. 그러나 업데이트 또는 삽입 작업을 실행할 때는 이 메서드가 필요하지 않습니다.

잘못된 코드의 예

다음 코드는 데이터베이스 테이블을 업데이트하고 모든 항목을 검색하려고 시도합니다. fetchAll()을 사용하여 행을 업데이트했습니다.

try {
    $stmt = $pdo->prepare("UPDATE $page SET $section = :new_content WHERE $section = '$old_content'");
    $stmt->execute(array('new_content' => $new_content));
    $result = $stmt->fetchAll();
    echo "Database updated!";
}
catch(PDOException $e) {
    echo 'ERROR UPDATING CONTENT: ' . $e->getMessage();
}

이 경우 업데이트 쿼리 후 fetchAll()을 사용했기 때문에 "SQLSTATE[HY000]: 일반 오류" 오류가 발생합니다.

올바른 해결책

이 오류를 수정하려면 코드에서 fetchAll() 문을 제거하면 됩니다. 수정된 코드는 다음과 같습니다.

try {
    $stmt = $pdo->prepare("UPDATE $page SET $section = :new_content WHERE $section = '$old_content'");
    $stmt->execute(array('new_content' => $new_content));
    echo "Database updated!";
}
catch(PDOException $e) {
    echo 'ERROR UPDATING CONTENT: ' . $e->getMessage();
}

fetchAll() 문을 생략하면 "SQLSTATE[HY000]: General error" 오류 메시지가 사라지고 데이터베이스 업데이트가 성공적으로 완료됩니다.

위 내용은 업데이트 쿼리 후 PDO가 성공 대신 \'SQLSTATE[HY000]\'을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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