MySQL에서 CASE 함수를 사용하여 다중 조건부 판단을 구현하는 방법
MySQL에서는 데이터에 대해 조건부 판단을 수행하고 다양한 조건에 따라 다양한 연산을 수행해야 하는 경우가 많습니다. CASE 기능은 여러 조건부 판단을 구현하고 조건에 따라 다양한 연산을 수행할 수 있는 매우 유용한 도구입니다.
CASE 함수의 구문은 다음과 같습니다.
CASE
WHEN Condition1 THEN result1
WHEN Condition2 THEN result2
...
ELSE result
END
여기서, 조건은 조건식이며, 가능한 모든 식일 수 있습니다. 부울 값을 반환합니다. 결과는 해당 조건이 충족될 때 수행해야 하는 작업입니다.
다음은 CASE 함수를 사용하여 다중 조건부 판단을 구현하는 방법을 보여주는 몇 가지 예입니다.
학생 정보와 성적이 포함된 학생 테이블이 있다고 가정합니다. 이제 점수를 기준으로 학생의 성적을 판단하려고 합니다. 점수가 80점 이상이면 A이고, 성적이 60점 이상 80점 미만이면 B입니다. 성적이 60점 미만이면 C입니다. 이는 다음 코드를 사용하여 달성할 수 있습니다:
SELECT
이름,
점수,
CASE
WHEN score >= 80 THEN 'A' WHEN score >= 60 THEN 'B' ELSE 'C'
END as grade
FROM
학생;
위의 예에서는 단일 조건 판단. 여러 조건을 바탕으로 판단해야 하는 경우 중첩된 CASE 함수를 사용할 수 있습니다.
주문 정보와 총 금액이 포함된 주문 테이블이 있다고 가정해 보겠습니다. 이제 총액을 기준으로 주문 수준을 판단하고자 합니다. 총액이 1,000 이상이면 상위 주문이고, 500 이상 1,000 미만이면 주문 수준입니다. 중급 주문이며, 총 금액이 500 미만일 경우 저급 주문입니다. 이는 다음 코드를 사용하여 달성할 수 있습니다:
SELECT
order_id,
total_amount,
CASE
WHEN total_amount >=1000 THEN '高级订单' WHEN total_amount >=500 THEN '中级订单' ELSE '低级订单'
END as level
FROM
주문;
사용 외에도 쿼리 문의 CASE 함수 외에도 업데이트 작업에 CASE 함수를 사용할 수도 있습니다. 예를 들어, 성적에 따라 학생의 성적을 업데이트하려는 경우 다음 코드를 사용하여 이를 달성할 수 있습니다:
UPDATE Students
SET grade =
CASE
WHEN score >= 80 THEN 'A' WHEN score >= 60 THEN 'B' ELSE 'C'
END;
요약:
MySQL에서, CASE 기능은 여러 조건부 판단을 구현하고 다양한 조건에 따라 다양한 작업을 수행할 수 있는 매우 유용한 도구입니다. 쿼리문이든 업데이트 작업이든 CASE 기능은 조건부 판단을 간결하고 유연하게 내리는 데 도움이 될 수 있습니다. 이 글의 샘플 코드가 독자들이 CASE 함수를 더 잘 이해하고 적용하는 데 도움이 되기를 바랍니다.
위 내용은 의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!