PDO에서 LIMIT 절을 사용하여 배열 매개변수를 전달할 때 오류를 해결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-23 19:46:31
원래의
624명이 탐색했습니다.

How to Resolve Error When Passing Array Parameters with LIMIT Clause in PDO?

LIMIT 절을 사용하여 PDO 매개변수 배열 전달

소개:

PDO 작업 시 , 매개변수 배열을 전달하고 LIMIT 절을 동시에 사용하는 것은 어려울 수 있습니다. 이 문서는 이 문제에 대한 해결책을 제공합니다.

문제 설명:

다음 SQL 쿼리가 주어진 경우:

SELECT * FROM table WHERE id LIKE CONCAT('%', :id, '%')
LIMIT :limit1, :limit2
로그인 후 복사

이를 실행하려고 합니다. 아래와 같이 매개변수 배열을 사용하여 쿼리합니다.

$stmt->execute($array);
로그인 후 복사

그러나 LIMIT 매개변수(:limit1 및 :limit2)에 대해 binParam() 메서드를 사용하면 오류가 발생합니다.

해결책:

해결책은 PDO::ATTR_EMULATE_PREPARES의 기본 PDO 설정을 비활성화하는 것입니다. 이 설정은 본질적으로 PDO가 준비된 문을 기본적으로 사용하는 대신 에뮬레이트하도록 지시합니다.

이 설정을 비활성화하려면:

$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
로그인 후 복사

이 설정이 비활성화되면 다음을 사용하여 쿼리를 준비하고 실행할 수 있습니다. LIMIT 값을 포함한 매개변수 배열:

$stmt = $pdo->prepare($sql);
$stmt->execute(array(5)); //works!
로그인 후 복사

의미:

PDO::ATTR_EMULATE_PREPARES를 비활성화하면 준비된 에뮬레이션의 오버헤드가 제거되므로 성능이 향상될 수 있습니다. 진술. 그러나 이 설정은 성능상의 이유로 기본적으로 활성화되어 있다는 점에 유의해야 합니다.

추가 리소스:

  • [PDO MySQL: PDO 사용:: ATTR_EMULATE_PREPARES 여부](https://pdosql.org/pdo-mysql-use-pdo-attr-emulate-prepares-or-not/)

위 내용은 PDO에서 LIMIT 절을 사용하여 배열 매개변수를 전달할 때 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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