MySQLi 쿼리의 여러 매개변수에 대한 유연한 바인딩
현재 여러 매개변수를 MySQLi 쿼리에 바인딩하려면 다음과 같은 반복 구조가 사용됩니다.
if ($words_total == 1) { $statement -> bind_param("s", $words[0]); } // ... more if-else conditions for each possible number of parameters ...
쿼리에 필요한 물음표 수를 계산하려면 다음을 수행하세요. 코드가 사용됩니다:
$marks = ""; for($i = 1; $i<=$words_total; $i++) { if ($i == $words_total) $marks .= "?"; else $marks .= "?,"; }
인수 압축 해제로 향상된 접근 방식
다행히도 PHP 5.6에서는 인수 압축 해제 연산자(...)를 도입하여 바인딩을 단순화합니다. 여러 매개변수. 정적 유형 문자열에 의존하는 대신 연산자를 배열과 함께 사용할 수 있습니다.
// create an array of parameter values $parameters = [$words[0], $words[1], ... $words]; // create a type string dynamically $types = str_repeat('s', count($parameters)); // bind the array using argument unpacking $statement -> bind_param($types, ...$parameters);
이 접근 방식을 사용하면 매개변수 수에 관계없이 바인딩을 동적으로 처리할 수 있습니다.
위 내용은 MySQLi 쿼리에서 여러 매개변수를 효율적으로 바인딩하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!