MySQL의 NULL 값 비교
MySQL에서는 NULL 값이 포함된 열을 비교하는 것이 표준 동등 비교와 동작이 다르기 때문에 문제가 발생할 수 있습니다. 이 문서에서는 'C'가 NULL이 아닌 경우에도 "SELECT * from CODE!='C'"와 같은 쿼리가 CODE=NULL인 행을 제외하는 이유를 살펴봅니다.
NULL 비교 동작
열을 NULL이 아닌 값(예: "CODE!='C'")과 비교할 때 쿼리는 CODE가 'C'와 일치하는 행을 반환하고 NULL을 포함한 다른 모든 값을 제외합니다. 이 동작은 SQL이 NULL을 표준 비교에 참여하지 않는 고유한 값으로 처리하기 때문에 발생합니다.
비교에 NULL 값을 포함하려면 IS NULL 또는 IS NOT NULL 연산자를 사용하여 명시적으로 확인해야 합니다. 예를 들어, 다음 쿼리는 CODE가 NULL이거나 'C'와 같지 않은 모든 행을 반환합니다.
<code class="language-sql">SELECT * from TABLE where CODE IS NULL OR CODE!='C'</code>
CODE!='C' 동작 설명
"CODE!='C'"가 CODE=NULL인 행을 반환하지 않는 이유는 쿼리가 NULL과 관련된 모든 비교에 대해 false로 평가되기 때문입니다. 'C'가 NULL이 아니더라도 이를 NULL 값과 비교하면 항상 false가 됩니다.
대체 비교 연산자
MySQL은 NULL이 포함된 값을 비교하는 데 사용할 수 있는 대체 비교 연산자 "<="(보다 작거나 같음)를 제공합니다. "x
"CODE!='C'" 대신 "CODE <= 'C' OR CODE IS NULL"을 사용하면 CODE가 NULL이거나 'C'와 같지 않은 모든 행을 반환할 수 있습니다.
위 내용은 'CODE!='C''가 MySQL 쿼리에서 NULL 값을 제외하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!