SQL Server의 조건부 WHERE 절: 구현 및 대안
SQL Server에서 조건부 WHERE 절을 사용하면 주어진 표현식의 값을 기반으로 필터 조건을 동적으로 적용할 수 있습니다. 다음 시나리오를 고려해보세요.
DateDropped
열이 특정 값과 일치하는 테이블에서 데이터를 검색하려고 합니다. 그러나 @JobsOnHold
이라는 매개변수를 기반으로 추가 필터를 적용하려고 합니다. @JobsOnHold
이 1로 설정된 경우 DateAppr
가 0보다 크거나 같은 레코드를 포함하려고 합니다. 그렇지 않으면 DateAppr
이 0인 레코드를 제외하려고 합니다.
제공하신 초기 검색어가 잘못되었습니다. CASE를 사용하는 조건부 WHERE 절의 올바른 구문은 다음과 같습니다.
<code class="language-sql">WHERE DateDropped = 0 AND CASE WHEN @JobsOnHold = 1 THEN DateAppr >= 0 ELSE DateAppr != 0 END</code>
그러나 CASE를 사용할 필요가 없는 더 간단한 대안이 있습니다.
<code class="language-sql">WHERE DateDropped = 0 AND ( (ISNULL(@JobsOnHold, 0) = 1 AND DateAppr >= 0) OR (ISNULL(@JobsOnHold, 0) != 1 AND DateAppr != 0) )</code>
이 버전에서는 ISNULL
함수를 사용하여 @JobsOnHold
가 NULL일 수 있는 경우를 처리합니다. @JobsOnHold
의 기본값은 0으로 설정되어 매개변수에 값이 할당되지 않은 경우에도 쿼리가 올바르게 실행되도록 합니다.
조건부 WHERE 절 이해
조건부 WHERE 절은 표현식을 평가하고 표현식이 참인지 거짓인지에 따라 결과를 필터링합니다. 식이 true이면 해당 행이 결과 집합에 포함됩니다. 그렇지 않으면 행이 제외됩니다.
조건 WHERE 절의 조건은 임의로 복잡할 수 있으므로 고도로 사용자 정의 가능한 필터링이 가능합니다. 예를 들어 지난 24시간 내에 추가된 모든 레코드를 제외하거나 특정 상태 코드가 있는 레코드만 포함하는 쿼리를 만들 수 있습니다.
조건부 WHERE 절의 대안
어떤 경우에는 조건부 WHERE 절을 사용하지 않고 원하는 결과를 얻을 수 있는 대안이 있을 수 있습니다. 예를 들어 COALESCE
함수를 사용하여 @JobsOnHold
이 NULL인 경우를 처리할 수 있습니다. 또는 @JobsOnHold
의 가능한 각 값에 대해 두 개의 별도 쿼리를 만들 수 있습니다.
그러나 조건부 WHERE 절은 SQL 쿼리에 복잡한 필터링 논리를 적용하는 간결하고 효율적인 방법을 제공합니다. 작동 방식과 존재하는 대안을 이해하면 이를 효과적으로 사용하여 필요한 데이터를 검색할 수 있습니다.
위 내용은 대안을 사용하여 SQL Server에서 조건부 WHERE 절을 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!