> 백엔드 개발 > PHP 튜토리얼 > mysqli 쿼리에서 여러 매개변수를 동적으로 바인딩하려면 어떻게 해야 합니까?

mysqli 쿼리에서 여러 매개변수를 동적으로 바인딩하려면 어떻게 해야 합니까?

Mary-Kate Olsen
풀어 주다: 2024-12-24 06:25:11
원래의
192명이 탐색했습니다.

How Can I Dynamically Bind Multiple Parameters in mysqli Queries?

mysqli 쿼리에서 여러 매개변수의 동적 바인딩

전통적으로 PHP 개발자는 여러 매개변수를 바인딩하기 위해 긴 조건문이나 수동 연결에 의존해 왔습니다. mysqli 쿼리. 이 작업은 지루하고 오류가 발생하기 쉽습니다.

하드코딩된 매개변수 바인딩

제공하신 예는 물음표 수와 매개변수 유형을 수동으로 지정하는 하드코딩된 접근 방식을 보여줍니다. 입력값 개수에 따라 조정됩니다. 이것이 작동하기는 하지만 동적 쿼리를 처리하는 데 이상적인 솔루션은 아닙니다.

인수 압축 해제 연산자

다행히도 PHP 5.6에서는 인수 압축 해제 연산자(...)를 도입했습니다. 여러 개의 개별 인수가 필요한 함수에 배열을 매개변수로 전달할 수 있습니다.

해결책 Argument Unpacking

PHP 5.6에서 임의 개수의 매개변수를 동적으로 바인딩하려면 다음 접근 방식을 사용할 수 있습니다.

1. 유형 문자열 생성: 매개변수 유형에 해당하는 문자(예: 문자열은 s)를 매개변수 개수만큼 연결합니다.

$types = str_repeat('s', count($array)); // returns sss...
로그인 후 복사

2. 매개변수 바인딩: 인수 압축 해제 연산자를 사용하여 매개변수 값 배열유형 문자열과 함께 개별 매개변수로 전달합니다.

$stmt->bind_param($types, ...$array); 
로그인 후 복사

예:

$array = ['a','b','c']; 
$sql   = "SELECT name FROM table WHERE city IN (?,".str_repeat('?,', count($array) - 2).")"; //  returns ?,?,?...
$stmt  = $mysqli->prepare($sql);
$stmt->bind_param('s', ...$array); 
$stmt->execute();
로그인 후 복사

이 접근 방식은 우아하게 처리됩니다. 조건문이나 수동 연결이 필요 없이 입력 매개변수를 원하는 만큼 입력할 수 있습니다.

위 내용은 mysqli 쿼리에서 여러 매개변수를 동적으로 바인딩하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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