> 데이터 베이스 > MySQL 튜토리얼 > NULL 값을 처리하는 동안 불일치를 찾기 위해 여러 MySQL 테이블을 효율적으로 쿼리하는 방법은 무엇입니까?

NULL 값을 처리하는 동안 불일치를 찾기 위해 여러 MySQL 테이블을 효율적으로 쿼리하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-27 02:34:09
원래의
563명이 탐색했습니다.

How to Efficiently Query Multiple MySQL Tables to Find Discrepancies While Handling NULL Values?

여러 테이블을 쿼리하는 MySQL "NOT IN"

주어진 MySQL 쿼리는 Grade에서 존재하는 행을 제외하여 Grade와 Evaluation 테이블의 데이터 간의 불일치를 식별하려고 합니다. 평가 중. 그러나 지정된 이름("JOHN")이 평가에서 발견되지 않으면 원래 쿼리는 결과를 검색하지 못합니다.

"NOT IN" 문제 이해

"NOT IN" 원래 쿼리에 사용된 연산자는 관련된 열에 NULL 값이 포함될 수 있는 경우 문제가 됩니다. MySQL에서 NULL은 알 수 없거나 누락된 값을 나타내며 특정 연산자와의 상호 작용으로 인해 예상치 못한 결과가 발생할 수 있습니다.

해결책: "NOT IN" 방지

이 문제를 해결하려면 다음을 수행하는 것이 좋습니다. NULL이 포함될 수 있는 열을 처리할 때는 "NOT IN"을 사용하지 마세요. 대신 대체 접근 방식을 사용해 보세요.

  • EXPLICIT JOINS: 테이블 조인에 WHERE 절을 사용하는 대신 JOIN 문을 사용하여 조인을 명시적으로 지정합니다. 이를 통해 더 정확하고 예측 가능한 결과를 얻을 수 있습니다.
  • NOT EXISTS SUBQUERY: 중첩된 NOT EXISTS 하위 쿼리를 사용하여 한 테이블의 행이 다른 테이블에는 존재하지 않는지 확인하세요.

예: NOT EXISTS 사용

다음 수정된 쿼리는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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