>백엔드 개발 >PHP 튜토리얼 >mysqli 바인딩_param()에서 '참조가 될 것으로 예상됨' 오류를 해결하는 방법은 무엇입니까?

mysqli 바인딩_param()에서 '참조가 될 것으로 예상됨' 오류를 해결하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-13 10:57:15234검색

How to Solve the

mysqli bind_param()에서 "참조로 예상됨" 오류 처리

"mysqli_stmt::bind_param(에 대한 매개변수 3" 오류 메시지 ) 참조가 될 것으로 예상되며 값이 제공됨"은 준비된 문에 값을 바인딩할 때 발생합니다. 이 문제를 해결하려면 제공된 값이 값 자체가 아닌 실제 변수에 대한 참조여야 합니다.

제공된 코드 조각에서 $params 배열에는 참조가 아닌 값이 포함되어 있습니다. 값을 올바르게 바인딩하려면 다음 접근 방식을 사용할 수 있습니다.

$query = "INSERT INTO test (id,row1,row2,row3) VALUES (?,?,?,?)";
$param_type = "isss";

// PHP 7+
$sql_stmt = mysqli_prepare($mysqli, $query);
mysqli_stmt_bind_param($sql_stmt, $param_type, ...$params);

// PHP 5.6 - 7.0
$sql_stmt = mysqli_prepare($mysqli, $query);
$arr = array($sql_stmt, $param_type);
foreach ($params as $param) {
    $arr[] = &$param;
}
call_user_func_array('mysqli_stmt_bind_param', $arr);

mysqli_stmt_execute($sql_stmt);

참조 사용

PHP 5.3 이하에서는 값 바인딩에 참조가 필요하지 않습니다. 준비된 진술에. 그러나 PHP 5.4부터는 참조가 필수입니다. 이렇게 변경하는 이유는 원치 않는 변수 복사 및 잠재적인 메모리 누수를 방지하기 위한 것입니다.

참조를 사용하면 바인딩된 값이 직접 수정되어 추가 변수 할당이 필요하지 않으므로 바인딩 프로세스가 더욱 효율적이 됩니다.

결론

참조가 아닌 값으로 mysqli의 bind_param()을 사용할 때, 이를 참조로 전달하거나 대체 접근 방식을 사용하여 값을 올바르게 바인딩해야 합니다. 이를 통해 SQL 쿼리를 효율적이고 오류 없이 실행할 수 있습니다.

위 내용은 mysqli 바인딩_param()에서 '참조가 될 것으로 예상됨' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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