MySQL의 공정 제어 기능

만약 다른 결과 : 기능의 경우

SELECT IF(10<5,'大','小'); #第一个表达式为真则返回第二个参数否则返回第三个
#案例:
SELECT 
    last_name,
    commission_pct,
    IF(commission_pct IS NULL,'没奖金','有奖金')
FROM 
    employees;

케이스 기능 : 효과 경우 전환 비슷
# 케이스 :; 40,1.2 배, 50,1.3 배, 급여가 1.1 배 쿼리 임금 부서 번호 30 원래 임금의 다른 분야

SELECT salary AS 原始工资,department_id,

CASE department_id 
WHEN 30 THEN salary*1.1
WHEN 40 THEN salary*1.2
WHEN 50 THEN salary*1.3
ELSE salary     #相当于switch中的default:
END  AS  新工资 #结束
FROM employees;

사용 사례 2 :; 여러 유사 후 후 표시 값이 추가되지 않은 경우,이 경우 식 후 추가
쿼리의 직원 임금의 경우 : 사례 #

SELECT 
    salary,
    CASE
    WHEN salary >20000 THEN 'a'
    WHEN salary >15000 THEN 'b'
    WHEN salary >10000 THEN 'c'
    ELSE 'd'
    END AS 等级
FROM 
    employees;

추천

출처blog.51cto.com/14437184/2435964