SQL이 If-Then-Else 논리를 처리할 수 있나요?
우선순위에 따라 테이블에서 데이터를 검색해야 하는데 SQL에서 이에 접근하는 방법을 잘 모르겠습니다. 이 쿼리를 자세히 살펴보고 조건부 논리 처리 옵션을 살펴보겠습니다.
SQL에서 조건부 논리 처리
기존 프로그래밍 언어와 달리 SQL은 if-then을 갖지 않습니다. -else 문. 그러나 조건부 논리를 모방하는 방법에는 여러 가지가 있습니다.
CASE 문 사용
CASE 문은 조건부 논리를 처리하는 유연한 방법을 제공합니다. 여러 조건을 지정하고 각 조건에 따라 다른 결과를 반환할 수 있습니다. 예는 다음과 같습니다.
SELECT CASE WHEN (SELECT COUNT(*) FROM table1 WHERE project = 1) > 0 THEN (SELECT product, price FROM table1 WHERE project = 1) WHEN (SELECT COUNT(*) FROM table1 WHERE customer = 2) > 0 THEN (SELECT product, price FROM table1 WHERE customer = 2) WHEN (SELECT COUNT(*) FROM table1 WHERE company = 3) > 0 THEN (SELECT product, price FROM table1 WHERE company = 3) ELSE 'No price found' END;
IF-THEN-ELSE 문 사용(절차 SQL)
절차 SQL에서는 IF-THEN-ELSE 문을 사용할 수 있습니다. 조건을 확인하고 결과에 따라 다양한 쿼리 블록을 실행합니다. MS SQL은 IF-THEN-ELSE를 직접 지원하지 않습니다. 그러나 CASE 문이나 sp_if 문을 사용하여 시뮬레이션할 수 있습니다.
UNION 연산자 사용
UNION 연산자를 사용하면 여러 쿼리의 결과를 하나의 쿼리로 결합할 수 있습니다. 단일 결과 집합. 이 접근 방식은 이전 쿼리가 먼저 확인되므로 하나의 쿼리를 다른 쿼리보다 우선순위로 두려는 경우 유용합니다.
SELECT product, price FROM table1 WHERE project = 1 UNION SELECT product, price FROM table1 WHERE customer = 2 UNION SELECT product, price FROM table1 WHERE company = 3;
위 내용은 SQL 쿼리에서 If-Then-Else 논리를 어떻게 구현할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!