주어진 MySQL 쿼리는 Grade에서 존재하는 행을 제외하여 Grade와 Evaluation 테이블의 데이터 간의 불일치를 식별하려고 합니다. 평가 중. 그러나 지정된 이름("JOHN")이 평가에서 발견되지 않으면 원래 쿼리는 결과를 검색하지 못합니다.
"NOT IN" 원래 쿼리에 사용된 연산자는 관련된 열에 NULL 값이 포함될 수 있는 경우 문제가 됩니다. MySQL에서 NULL은 알 수 없거나 누락된 값을 나타내며 특정 연산자와의 상호 작용으로 인해 예상치 못한 결과가 발생할 수 있습니다.
이 문제를 해결하려면 다음을 수행하는 것이 좋습니다. NULL이 포함될 수 있는 열을 처리할 때는 "NOT IN"을 사용하지 마세요. 대신 대체 접근 방식을 사용해 보세요.
다음 수정된 쿼리는 NOT을 사용합니다. 원하는 결과를 얻으려면 EXISTS:
SELECT G.ID_Courses, C.ID_Courses, G.NAME, C.NAME, G.ID_Courses, E.NAME, E.Year, G.Year FROM Grade AS G INNER JOIN Course AS C ON G.ID_Courses = C.ID_Courses LEFT JOIN Evaluation AS E ON G.NAME = E.NAME AND G.Year = E.Year WHERE NOT EXISTS( SELECT 1 FROM Evaluation WHERE NAME = G.NAME AND Year = G.Year ) AND G.NAME = 'JOHN' AND G.Year = 1 GROUP BY G.ID_Courses;
NOT EXISTS를 사용하면 이 쿼리는 평가에 해당 행이 없는 Grade의 행이 여전히 출력에 포함되도록 보장합니다.
위 내용은 NULL 값을 처리하는 동안 불일치를 찾기 위해 여러 MySQL 테이블을 효율적으로 쿼리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!