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