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