> 데이터 베이스 > MySQL 튜토리얼 > 내 SQL `NOT IN` 절이 NULL 값과 함께 작동하지 않는 이유는 무엇입니까?

내 SQL `NOT IN` 절이 NULL 값과 함께 작동하지 않는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-18 11:21:09
원래의
433명이 탐색했습니다.

Why Doesn't My SQL `NOT IN` Clause Work with NULL Values?

SQL의 NOT IN 절 및 NULL 값 문제 해결

이 문서에서는 SQL 쿼리에서 NOT IN 절을 사용할 때 발생하는 일반적인 문제(NULL 값으로 인해 예기치 않게 결과 집합이 비어 있음)를 다룹니다. 이 시나리오에는 Stock 테이블(Inventory 데이터베이스)에 없는 레코드를 Products 테이블(Subset 데이터베이스)에서 선택하는 작업이 포함됩니다.

NOT IN 테이블의 foreignStockId 열에 NULL 값이 포함된 경우 Products 절이 예상대로 작동하지 않습니다. NOT IN 하위 쿼리의 결과 집합에 NULL이 하나만 있어도 전체 쿼리에서 아무 행도 반환되지 않습니다.

해결책:

이 문제를 해결하려면 NULL 값을 명시적으로 제외해야 합니다. 두 가지 효과적인 접근 방식이 제시됩니다:

1. IS NOT NULL 사용:

이 접근 방식은 NOT IN 하위 쿼리에서 NULL을 필터링합니다.

<code class="language-sql">SELECT stock.IdStock, stock.Descr
FROM   [Inventory].[dbo].[Stock] stock
WHERE  stock.IdStock NOT IN (SELECT foreignStockId
                             FROM   [Subset].[dbo].[Products]
                             WHERE  foreignStockId IS NOT NULL);</code>
로그인 후 복사

2. NOT EXISTS 사용:

NOT EXISTS 절은 더 효율적이고 더 명확한 대안을 제공합니다.

<code class="language-sql">SELECT stock.idstock, stock.descr
FROM   [Inventory].[dbo].[Stock] stock
WHERE  NOT EXISTS (SELECT *
                   FROM   [Subset].[dbo].[Products] p
                   WHERE  p.foreignstockid = stock.idstock);</code>
로그인 후 복사

문제 이해: 3값 논리

SQL은 True, False, Unknown이라는 세 가지 값 논리를 사용합니다. 행이 결과 집합에 포함되려면 WHERE 절이 True로 평가되어야 합니다. 문제는 'A' <> NULLUnknown으로 평가되기 때문에 발생합니다. Unknown 비교에 NOT IN이 있으면 전체 식이 Unknown가 되어 빈 결과 집합이 생성됩니다.

예시:

다음 사항을 고려하세요.

Predicate True False Unknown
'A' NOT IN ('X','Y',NULL) True True Unknown

Unknown 결과는 'A'와 NULL을 비교한 결과입니다. 따라서 전체 WHERE 절은 Unknown으로 평가되며 행이 반환되지 않습니다.

IS NOT NULL 또는 NOT EXISTS을 사용하면 이러한 모호성을 우회하고 쿼리가 의도한 결과를 반환하도록 할 수 있습니다. NOT EXISTS 접근 방식은 이러한 시나리오에서 향상된 성능과 가독성 때문에 선호되는 경우가 많습니다.

위 내용은 내 SQL `NOT IN` 절이 NULL 값과 함께 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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