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