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

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

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-11 05:26:10376검색

How Can I Efficiently Bind Multiple Parameters in MySQLi Queries?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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