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