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 중국어 웹사이트의 기타 관련 기사를 참조하세요!