>데이터 베이스 >MySQL 튜토리얼 >CASE 문을 사용하여 MySQL의 조건에 따라 값을 할당하려면 어떻게 해야 합니까?

CASE 문을 사용하여 MySQL의 조건에 따라 값을 할당하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-11-03 23:57:30276검색

How Can I Use the CASE Statement to Assign Values Based on Conditions in MySQL?

MySQL CASE 이해: 종합 가이드

SQL 데이터베이스로 작업할 때 의미 있는 통찰력을 추출하기 위해 데이터를 조작하는 것은 필수적입니다. CASE 문은 조건부로 SQL 문을 실행하는 강력한 도구를 제공하므로 복잡한 데이터 변환 및 평가를 수행할 수 있습니다.

CASE 구문 공개

SQL CASE 문은 다음과 같습니다. 구조화된 형식:

CASE
    WHEN condition1 THEN result1
    [WHEN condition2 THEN result2] ...
    [ELSE default_result]
END CASE

CASE를 활용하여 원하는 결과를 얻을 수 있는 방법은 다음과 같습니다.

예: 역할 순서 할당

"관리자", "파트타임" 등과 같은 역할을 포함하는 user_role 테이블에 필드가 있습니다. 역할에 따라 번호를 할당하는 role_order라는 새 필드를 생성하려고 합니다.

CASE를 사용한 솔루션:

CASE
    WHEN user_role = 'Manager' THEN 5
    WHEN user_role = 'Part Time' THEN 3
    ELSE -1 -- Handle unknown roles
END CASE

이 CASE 문은 스위치 문처럼 작동합니다. , user_role 값을 평가하고 사전 정의된 조건에 따라 해당 role_order 번호를 할당합니다.

CASE 구현 이해

CASE는 포괄적인 평가 문 역할을 한다는 점에서 IF 문과 다릅니다. 첫 번째 WHEN 조건을 평가하여 시작하고 해당 결과를 실행합니다. 조건이 충족되지 않으면 일치하는 조건을 찾을 때까지 다음 WHEN 조건으로 이동합니다. 일치하는 WHEN 조건이 없으면 선택적 ELSE 절이 기본 결과를 제공합니다.

단일 값 평가를 위한 단순화된 CASE 구문

CASE에 대한 대체 구문을 평가할 때 사용할 수 있습니다. 단일 값:

CASE value
    WHEN condition1 THEN result1
    [WHEN condition2 THEN result2] ...
    [ELSE default_result]
END CASE

이 구문은 user_role 값을 확인하는 예와 같이 하나의 특정 값을 검사할 때 명령문을 단순화합니다.

위 내용은 CASE 문을 사용하여 MySQL의 조건에 따라 값을 할당하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.