> 데이터 베이스 > MySQL 튜토리얼 > SQL 쿼리에서 If-Then-Else 논리를 어떻게 구현할 수 있습니까?

SQL 쿼리에서 If-Then-Else 논리를 어떻게 구현할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-19 04:59:08
원래의
828명이 탐색했습니다.

How Can I Implement If-Then-Else Logic in SQL Queries?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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