WHERE IN(?) 절에 문자열 배열 바인딩
WHERE IN(?) 절에 값 배열 바인딩 일반적인 MySQL 작업입니다. PHP의 mysqli 준비된 문을 사용할 때, 바인딩_param() 함수의 제한 사항과 미묘한 차이에 익숙하지 않으면 달성하기 어려울 수 있습니다.
문제
bind_param()을 사용하여 값 배열을 IN(?) 절에 바인딩하려고 할 때 문제가 발생하여 실패할 수 있습니다.
솔루션
사용 중인 PHP 버전에 따라 이 작업에 접근하는 방법은 다양합니다.
PHP 8.2 및 위
PHP 8.1
이전 PHP 버전
이전 버전의 경우 더 정교한 접근 방식이 필요합니다.
예제 코드
다음은 이전 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!