PHP MySQLi용 동적 바인딩
동적 매개변수 바인딩
PHP MySQLi에서,bind_param () 메소드를 사용하면 준비된 명령문에 매개변수를 바인딩할 수 있습니다. 그러나 매개변수의 수량과 유형이 다를 수 있는 동적 바인딩의 경우 기본 방법은 부족합니다.
해결책
이 제한을 극복하려면 다음과 같은 해결 방법을 사용할 수 있습니다. 채용:
Unpacking Operator를 사용하여 get_result()
PHP 5.6 이상에서는 압축 해제 연산자(...)와 get_result()를 사용하여 동적 바인딩을 단순화할 수 있습니다.
public function get_custom_result($sql, $types = null, $params = null) { $stmt = $this->mysqli->prepare($sql); $stmt->bind_param($types, ...$params); if (!$stmt->execute()) return false; return $stmt->get_result(); }
예
이 예는 매개변수를 동적으로 바인딩하고 결과:
$mysqli = new database(DB_HOST, DB_USER, DB_PASS, DB_NAME); $output = new search($mysqli); $sql = "SELECT * FROM root_contacts_cfm WHERE root_contacts_cfm.cnt_id = ? AND root_contacts_cfm.cnt_firstname = ? ORDER BY cnt_id DESC"; $res = $output->get_custom_result($sql, 'ss', array('1', 'Tk')); while ($row = $res->fetch_assoc()) { echo $row['fieldName'] . '<br>'; }
이 접근 방식은 함수 호출에 전달된 매개변수를 기반으로 매개변수를 바인딩하는 동적인 방법을 제공합니다.
위 내용은 PHP MySQLi에서 동적 매개변수 바인딩을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!