> 데이터 베이스 > MySQL 튜토리얼 > PHP에서 PDO prepare()를 사용하여 쿼리 준비 오류를 검색하고 처리하려면 어떻게 해야 합니까?

PHP에서 PDO prepare()를 사용하여 쿼리 준비 오류를 검색하고 처리하려면 어떻게 해야 합니까?

Mary-Kate Olsen
풀어 주다: 2024-12-23 09:22:18
원래의
948명이 탐색했습니다.

How Can I Retrieve and Handle Query Preparation Errors Using PDO prepare() in PHP?

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

PDO PHP로 작업할 때 오류를 처리해야 하는 상황이 발생할 수 있습니다. 쿼리 준비 중에 발생하는 문제입니다. 다음 코드 조각은 prepare() 메서드를 사용하여 쿼리를 준비하려고 시도하지만 실패할 경우 오류에 대한 추가 정보가 필요할 수 있습니다.

$st = $db->prepare("SELECT * FROM c6ode");
로그인 후 복사

쿼리에 대해 의도한 MySQL 오류를 검색하려면 необходимо 특정 단계를 따르십시오:

  1. 오류 설정 모드:
    setAttribute() 메서드를 사용하여 PDO 오류 보고 모드를 PDO::ERRMODE_EXCEPTION으로 구성합니다. 이 단계를 사용하면 오류가 발생할 때 PDO 객체가 예외를 발생시킬 수 있습니다.
  2. 에뮬레이트된 준비 비활성화(선택 사항):
    기본적으로 PDO는 준비된 문 준비를 에뮬레이트합니다. MySQL 서버가 검증을 위한 명령문을 실제로 수신하도록 하려면 PDO::ATTR_EMULATE_PREPARES를 false로 설정하여 이 기능을 비활성화하십시오.

다음은 이러한 단계를 보여주는 예제 코드 조각입니다.

<?php
$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 (?)');
?>
로그인 후 복사

위 코드로 인해 다음과 같은 예외가 발생합니다. message:

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

이러한 단계를 따르면 PDO PHP의 prepare() 메소드를 사용하여 쿼리 준비 중에 발생하는 오류를 효과적으로 검색하고 처리할 수 있습니다.

위 내용은 PHP에서 PDO prepare()를 사용하여 쿼리 준비 오류를 검색하고 처리하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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