> 백엔드 개발 > PHP 튜토리얼 > PHP에서 PDO prepare() 쿼리 오류를 어떻게 검색할 수 있나요?

PHP에서 PDO prepare() 쿼리 오류를 어떻게 검색할 수 있나요?

Barbara Streisand
풀어 주다: 2024-12-06 22:40:12
원래의
173명이 탐색했습니다.

How Can I Retrieve PDO Prepare() Query Errors in PHP?

PDO PHP의 prepare()에서 쿼리 오류 검색

PDO PHP를 사용하여 쿼리를 준비하는 경우 잠재적인 오류가 있는지 확인하는 것이 중요합니다. 오류. 기본적으로 PDO는 쿼리 준비 중에 발생한 오류에 대해 예외를 발생시키지 않습니다. 오류 처리를 활성화하려면 PDO::ATTR_ERRMODE 속성을 활용할 수 있습니다.

솔루션

  • PDO::ATTR_ERRMODE를 PDO::ERRMODE_EXCEPTION으로 설정합니다. : 이 속성을 설정하면 prepare()가 오류가 발생하면 예외가 발생합니다.
  • PDO::ATTR_EMULATE_PREPARES:를 비활성화합니다. MySQL 서버가 prepare() 중에 쿼리를 처리하도록 하려면 이 속성을 비활성화합니다. 에뮬레이션으로 인해 쿼리가 실행될 때까지 서버가 오류를 감지하지 못하는 경우가 있습니다.

예:

$pdo = new PDO('mysql:host=localhost;dbname=test;charset=utf8', 'localonly', 'localonly');
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
$pdo->prepare('INSERT INTO DoesNotExist (x) VALUES (?)');
로그인 후 복사

제공된 쿼리에 잘못된 구문이 포함된 경우 PDO는 오류를 발생시킵니다. 다음 정보에 대한 예외:

SQLSTATE[42S02]: Base table or view not found: 
1146 Table 'test.doesnotexist' doesn't exist
로그인 후 복사

위 내용은 PHP에서 PDO prepare() 쿼리 오류를 어떻게 검색할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿