mysql 流程控制函数

if 函数:if else 的效果

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

case函数: 类似于switch case 的效果
#案例:查询员工的工资部门号=30,工资为1.1倍;40,1.2倍;50,1.3倍;其他部门为原工资

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;

case使用2:类似于多重if,then 后显示的为值则不加;如果是表达式则加;
#案例:查询员工的工资的情况

SELECT 
    salary,
    CASE
    WHEN salary >20000 THEN 'a'
    WHEN salary >15000 THEN 'b'
    WHEN salary >10000 THEN 'c'
    ELSE 'd'
    END AS 等级
FROM 
    employees;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值