>백엔드 개발 >PHP 튜토리얼 >`mysqli_query()`가 '매개변수 1이 mysqli, null이 주어질 것으로 예상합니다'를 반환하는 이유는 무엇입니까?

`mysqli_query()`가 '매개변수 1이 mysqli, null이 주어질 것으로 예상합니다'를 반환하는 이유는 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-15 00:58:17342검색

Why Does `mysqli_query()` Return

경고: mysqli_query()는 매개변수 1이 mysqli일 것으로 예상합니다. null이 주어지면

이 오류는 mysqli_query를 사용하여 MySQL 쿼리를 실행하려고 할 때 발생합니다. (), 그러나 연결 객체에 제공된 매개변수는 유효한 MySQLi 객체가 아닙니다. mysqli_query() 함수는 첫 번째 매개변수가 mysqli 클래스의 인스턴스일 것으로 예상합니다.

제공된 코드 조각에서 오류는 다음과 같은 이유로 인해 발생할 가능성이 높습니다.

Scoping 문제

전역 범위에 선언된 mysqli 연결 개체 $con이 그렇지 않습니다. getPosts() 함수 내에서 액세스할 수 있습니다. 이로 인해 null 값이 mysqli_query()의 첫 번째 매개변수로 전달되어 오류가 발생합니다.

해결책:

이 문제를 해결하려면 명시적으로 다음을 수행할 수 있습니다. 연결 객체를 getPosts() 함수에 매개변수로 전달합니다. 수정된 코드는 다음과 같습니다.

function getPosts(mysqli $con) {
    $query = mysqli_query($con, "SELECT * FROM Blog");
    // ... Rest of the code remains the same
}

이제 getPosts() 함수를 호출할 때 연결 개체를 인수로 전달해야 합니다.

또한, 오류를 보고하고 데이터베이스 연결 문제를 적절하게 처리합니다. 예는 다음과 같습니다.

// Enable error reporting
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);

// Establish database connection
$con = mysqli_connect("localhost", "xxxx", "xxxx", "xxxxx");

// Check connection status
if (!$con) {
    throw new Exception('Failed to connect to MySQL: ' . mysqli_connect_error());
}

// Call the getPosts() function with the connection object
getPosts($con);

위 내용은 `mysqli_query()`가 '매개변수 1이 mysqli, null이 주어질 것으로 예상합니다'를 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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