>백엔드 개발 >PHP 튜토리얼 >'mysqli_stmt::bind_param() 예상되는 참조, 값 제공' 오류를 해결하는 방법은 무엇입니까?

'mysqli_stmt::bind_param() 예상되는 참조, 값 제공' 오류를 해결하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-01 14:04:101050검색

How to Resolve the

mysqli bind_param() 매개변수 참조 오류: RefValues ​​함수로 해결

"mysqli_stmt::bind_param()이 예상됨" 오류가 나타나는 이유는 무엇입니까? 참고용으로, 값이 지정되었습니다."?

오류 "mysqli_stmt::bind_param()이 참조로 예상되고 값이 지정됨"은 참조가 필요한 바인딩_param() 메서드에 변수 또는 값을 값으로 전달하려고 할 때 발생합니다. 이 문제는 call_user_func_array()를 사용하여 여러 매개변수를 바인딩_param()에 전달할 때 발생할 수 있습니다.

문제 이해

bind_param()을 포함한 MySQLi 함수에는 변수 전달이 필요합니다. 최적의 성능을 위한 참고 자료로 사용됩니다. 그러나 call_user_func_array()는 매개변수를 값으로 기대합니다. 기대치의 불일치로 인해 오류가 발생합니다.

해결책: RefValues() 함수 사용

이 문제를 해결하려면 refValues() 함수를 사용하면 됩니다. 값 배열을 참조 배열로 변환합니다. 예는 다음과 같습니다.

function refValues($arr){
    if (strnatcmp(phpversion(),'5.3') >= 0) //Reference is required for PHP 5.3+
    {
        $refs = array();
        foreach($arr as $key => $value)
            $refs[$key] = &$arr[$key];
        return $refs;
    }
    return $arr;
}

$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$param_type = "isss";
$sql_stmt = mysqli_prepare ($mysqli, $query);
call_user_func_array('mysqli_stmt_bind_param', array_merge(array($sql_stmt, $param_type), refValues($params)));
mysqli_stmt_execute($sql_stmt);

대체 솔루션: 스프레드 연산자 사용

최신 버전의 PHP에서는 스프레드 연산자(...)를 사용하여 변환할 수 있습니다. 값 배열을 참조 배열로 변환합니다. 예는 다음과 같습니다.

$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$params = array(1,"2","3","4");
$param_type = "isss";
$sql_stmt = mysqli_prepare ($mysqli, $query);
call_user_func_array([$sql_stmt, 'bind_param'], [$param_type, ...$params]);
mysqli_stmt_execute($sql_stmt);

위 내용은 'mysqli_stmt::bind_param() 예상되는 참조, 값 제공' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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