>백엔드 개발 >PHP 튜토리얼 >PHP의 mysqli 준비된 문을 사용하여 문자열 배열을 MySQL WHERE IN(?) 절에 효율적으로 바인딩하는 방법은 무엇입니까?

PHP의 mysqli 준비된 문을 사용하여 문자열 배열을 MySQL WHERE IN(?) 절에 효율적으로 바인딩하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-24 01:57:13940검색

How to Efficiently Bind an Array of Strings to a MySQL WHERE IN(?) Clause Using PHP's mysqli Prepared Statements?

WHERE IN(?) 절에 문자열 배열 바인딩

WHERE IN(?) 절에 값 배열 바인딩 일반적인 MySQL 작업입니다. PHP의 mysqli 준비된 문을 사용할 때, 바인딩_param() 함수의 제한 사항과 미묘한 차이에 익숙하지 않으면 달성하기 어려울 수 있습니다.

문제

bind_param()을 사용하여 값 배열을 IN(?) 절에 바인딩하려고 할 때 문제가 발생하여 실패할 수 있습니다.

솔루션

사용 중인 PHP 버전에 따라 이 작업에 접근하는 방법은 다양합니다.

PHP 8.2 및 위

  • execute_query() 함수: 이 함수를 사용하면 배열 값을 IN(?)에 직접 전달할 수 있습니다. 한 줄의 코드로 프로세스를 단순화합니다.

PHP 8.1

  • 실행할 배열 전달(): PHP 8.1에서는 준비된 명령문을 실행하기 위해 배열을 직접 실행()에 전달할 수 있으므로 여러 문장을 더 쉽게 바인딩할 수 있습니다. 값을 사용합니다.

이전 PHP 버전

이전 버전의 경우 더 정교한 접근 방식이 필요합니다.

  1. 다음을 사용하여 문자열을 만듭니다. 배열의 요소 수만큼 물음표(?)를 추가합니다.
  2. 자리 표시자와 함께 문자열을 추가합니다. 쿼리 문자열.
  3. str_repeat()를 사용하여 유형 문자열을 생성하여 올바른 유형(예: 문자열의 경우 's')으로 데이터를 바인딩합니다.
  4. 다음을 사용하여 배열 요소를 문에 바인딩합니다. Bind_param()의 인수 풀기 연산자(...).
  5. 문을 실행하고 결과를 검색합니다. data.

예제 코드

다음은 이전 PHP 버전의 접근 방식을 사용한 예입니다.

$array = ['Nashville', 'Knoxville'];
$in = str_repeat('?,', count($array) - 1) . '?';
$sql = "SELECT name FROM table WHERE city IN ($in)";
$stmt = $mysqli->prepare($sql); // prepare
$types = str_repeat('s', count($array)); // types
$stmt->bind_param($types, ...$array); // bind array at once
$stmt->execute();
$result = $stmt->get_result();
$data = $result->fetch_all(MYSQLI_ASSOC);

이러한 접근 방식을 이해함으로써, mysqli의 준비된 문을 사용하여 문자열 배열을 WHERE IN(?) 절에 효율적으로 바인딩하여 성공적인 실행을 보장할 수 있습니다. 쿼리합니다.

위 내용은 PHP의 mysqli 준비된 문을 사용하여 문자열 배열을 MySQL WHERE IN(?) 절에 효율적으로 바인딩하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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