> 데이터 베이스 > MySQL 튜토리얼 > NULL 값은 SQL의 NOT IN 절 결과에 어떤 영향을 줍니까?

NULL 값은 SQL의 NOT IN 절 결과에 어떤 영향을 줍니까?

Patricia Arquette
풀어 주다: 2025-01-23 12:51:13
원래의
678명이 탐색했습니다.

How Do NULL Values Affect the Results of SQL's NOT IN Clause?

SQL의 NOT IN 절과 NULL 값의 뉘앙스

SQL의 NOT IN 절은 지정된 목록 내의 값과 일치하는 행을 제외하는 역할을 합니다. 그러나 이 목록에 NULL 값이 있으면 복잡성이 발생합니다.

문제: NULL로 인한 예상치 못한 결과

다음 SQL 쿼리를 고려하세요.

<code class="language-sql">A: SELECT 'true' WHERE 3 IN (1, 2, 3, NULL);
B: SELECT 'true' WHERE 3 NOT IN (1, 2, NULL);</code>
로그인 후 복사

쿼리 A에서는 결과가 나오지만 쿼리 B에서는 결과가 나오지 않습니다. 이는 SQL이 NULL 비교를 처리하는 방식에서 비롯됩니다. 쿼리 A는 3이 목록의 어떤 값과 같은지 확인합니다. 3은 3이므로 결과를 반환합니다.

반대로 쿼리 B는 3이 모든 값과 같지인지 확인합니다. ANSI_NULLS를 활성화하면(많은 시스템의 기본값) NULL과 관련된 비교 결과는 UNKNOWN이 됩니다. UNKNOWN는 참도 거짓도 아닙니다. 따라서 쿼리 B는 행을 반환하지 않습니다.

ANSI_NULLS 설정과 영향

ANSI_NULLS를 비활성화하면 NULL 비교 동작이 변경됩니다. ANSI_NULLS를 끄면 NULL을 사용한 비교는 값이 같지 않으면 TRUE를 반환하고 같으면 FALSE를 반환합니다. 결과적으로 쿼리 B는 3 NOT IN (1, 2, NULL)가 TRUE로 평가되기 때문에 ANSI_NULLS가 비활성화된 결과를 반환합니다.

NULL의 본질 이해

NULL은 알 수 없는 값을 의미한다는 점을 기억하는 것이 중요합니다. NULL를 임의의 값과 비교하면 항상 UNKNOWN이 생성됩니다. 왜냐하면 동등성 또는 불평등이 명확하게 결정될 수 없기 때문입니다. NOT IN 값과 함께 NULL를 사용하는 경우 잠재적인 문제를 예상해야 하며, 강력한 쿼리 처리를 위해 명시적인 NULL 검사 또는 COALESCE을 사용하여 NULL를 알려진 값으로 바꾸는 등의 적절한 기술을 구현해야 합니다. .

위 내용은 NULL 값은 SQL의 NOT IN 절 결과에 어떤 영향을 줍니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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