데이터베이스를 쿼리할 때 'Null 유형 값의 배열 오프셋에 액세스하는 중' 오류가 발생하는 이유는 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-11 16:27:03
원래의
909명이 탐색했습니다.

Why Do I Get the

"Null 유형의 값에 대한 배열 오프셋 액세스 시도 중" 오류 수정

데이터베이스에서 데이터를 검색할 때 다음을 처리하는 것이 중요합니다. 일치하는 레코드가 없는 시나리오. 데이터베이스가 특정 쿼리에 대해 일치하는 행을 찾지 못한 경우 "Trying to access array offset on value of type null" 오류가 발생합니다.

이 오류가 발생하는 이유는 무엇입니까?

mysqli_fetch_array와 같은 데이터베이스 가져오기 함수는 일치하는 레코드가 없는 경우 null 값이나 빈 배열을 반환합니다. 이는 쿼리가 올바르지 않거나, 데이터가 존재하지 않거나, 결과 집합이 모두 소진된 경우 발생할 수 있습니다.

해결책 1: 진실성 및 키 존재 확인

이 문제를 해결하려면 반환된 값의 진실성을 확인하고 액세스하려는 특정 키가 존재하는지 확인할 수 있습니다. 예는 다음과 같습니다.

$monday_lectures = "SELECT * from lectures where lecture_time = '11am to 1pm' and lecture_day = 'firday'";
$result_11to1 = mysqli_query($con, $monday_lectures);
$m11to1 = mysqli_fetch_array($result_11to1);
if ($m11to1 && $m11to1["lecture_day"] != '') {
    echo "<td>".$m11to1["lecture_name"]."</td>";
} else {
    echo "<td> no class</td>";
}
로그인 후 복사

이 예에서는 먼저 $m11to1이 null이 아닌지 확인한 다음 "lecture_day" 키가 존재하고 빈 문자열이 아닌지 확인합니다.

해결책 2: PDO의 기본값

PDO로 작업하는 경우 일치하는 행이 없을 경우 결과에 대한 기본값을 지정할 수 있습니다.

$monday_lectures = $pdo->prepare("SELECT * from lectures where lecture_time = '11am to 1pm' and lecture_day = 'firday'");
$monday_lectures->execute();
$m11to1 = $monday_lectures->fetch();
$lecture = $m11to1["lecture_day"] ?? null;
로그인 후 복사

이렇게 하면 일치하는 레코드가 없더라도 $lecture가 null이 되지 않습니다.

위 내용은 데이터베이스를 쿼리할 때 'Null 유형 값의 배열 오프셋에 액세스하는 중' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿