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

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

Susan Sarandon
Susan Sarandon원래의
2024-12-19 20:33:11122검색

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

PDO 쿼리에서 배열 값을 IN() 조건에 바인딩할 수 있나요?

값 배열을 IN()에 바인딩 PDO를 사용한 조건은 가능하지만 수동으로 자리 표시자를 구성해야 합니다. 방법은 다음과 같습니다.

  1. 자리 표시자 만들기: 배열 요소 수에 해당하는 자리 표시자 문자열을 구성합니다. 예를 들어 배열에 세 개의 값이 포함된 경우 자리 표시자 문자열은 "?,?"입니다.
  2. 문 준비: 구성된 자리 표시자와 함께 IN() 조건을 사용하여 PDO 문을 준비합니다. .
  3. 문 실행: 준비된 문을 실행하고 배열 값을 인수로 전달합니다. PDO는 자동으로 값을 바인딩하고 인용합니다.

예:

$ids = [1, 2, 3, 7, 8, 9];
$inQuery = str_repeat('?,', count($ids) - 1) . '?'; // ?,?,?,?,?,?

$stmt = $db->prepare("SELECT * FROM table WHERE id IN($inQuery)");
$stmt->execute($ids);

이름이 지정된 자리 표시자의 경우:

  1. 만들기 자리 표시자 시퀀스: 배열 요소에 해당하는 명명된 자리 표시자의 시퀀스를 만듭니다. :id0,:id1,:id2.
  2. 값 수집: 자리 표시자 시퀀스를 키로 사용하여 배열 값을 키-값 배열로 수집합니다.
  3. 준비 및 실행: 명령문을 준비하고 실행하여 매개변수를 병합합니다.

예:

$ids = [1, 2, 3];
$in = "";
$i = 0; // external counter
foreach ($ids as $item) {
    $key = ":id" . $i++;
    $in .= ($in ? "," : "") . $key; // :id0,:id1,:id2
    $in_params[$key] = $item; // collect values
}

$sql = "SELECT * FROM table WHERE id IN ($in)";
$stmt = $db->prepare($sql);
$stmt->execute(array_merge(["foo" => "foo", "bar" => "bar"], $in_params));

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.