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' <> NULL
이 Unknown
으로 평가되기 때문에 발생합니다. 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!