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