> 백엔드 개발 > PHP 튜토리얼 > PDO의 IN() 절에 배열을 바인딩하려면 어떻게 해야 합니까?

PDO의 IN() 절에 배열을 바인딩하려면 어떻게 해야 합니까?

Patricia Arquette
풀어 주다: 2024-12-22 02:37:14
원래의
866명이 탐색했습니다.

How Can I Bind an Array to an IN() Clause in PDO?

PDO 쿼리의 IN() 조건에 배열 바인딩

개요

PHP의 PDO(PHP 데이터 개체)는 자리 표시자를 바인딩하는 메커니즘을 제공합니다. 배열의 값에 대한 쿼리에서. 그러나 값 배열을 IN() 조건에 바인딩하는 것은 기본적으로 지원하지 않습니다.

자리 표시자 문자열 작성

해결 방법으로 반복하여 자리 표시자 문자열을 수동으로 구성할 수 있습니다. 배열과 자리 표시자를 쉼표로 연결합니다.

$ids = [1, 2, 3, 7, 8, 9];
$in = str_repeat('?,', count($ids) - 1) . '?';
로그인 후 복사

$in 변수에는 다음과 같은 문자열이 포함됩니다. "?,?,?,?,?,?".

쿼리 준비 및 실행

자리 표시자 문자열을 사용하여 쿼리 준비:

$stmt = $db->prepare("SELECT * FROM table WHERE id IN($in)");
로그인 후 복사

쿼리하고 배열을 인수로 전달합니다.

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

대체 접근 방식: 이름 지정 자리 표시자

:id0, :id1, :id2 등과 같이 명명된 자리 표시자의 경우 수동으로 일련의 자리 표시자를 만들고 값을 연관 배열로 수집해야 합니다.

$i = 0;
$in_params = [];
foreach ($ids as $item) {
    $key = ":id" . $i++;
    $in_params[$key] = $item;
    $in .= ($in ? ',' : '') . $key;
}
로그인 후 복사

결론

PDO는 배열을 IN() 조건에 바인딩하는 것을 명시적으로 허용하지 않지만 다음과 같이 기능을 복제할 수 있습니다. 자리 표시자 문자열을 수동으로 생성하거나 연관 배열과 함께 명명된 자리 표시자를 사용합니다. 이러한 접근 방식은 PDO 쿼리 내에서 IN() 조건의 배열을 처리하는 편리한 방법을 제공합니다.

위 내용은 PDO의 IN() 절에 배열을 바인딩하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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