>백엔드 개발 >PHP 튜토리얼 >PHP MySQLi에서 동적 매개변수 바인딩을 달성하는 방법은 무엇입니까?

PHP MySQLi에서 동적 매개변수 바인딩을 달성하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-06 00:46:11917검색

How to Achieve Dynamic Parameter Binding in PHP MySQLi?

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

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