mysql使用IF,case控制流程执行不同的流程

方式一:case函数:流程控制函数

用法一:

CASE expression
WHEN value1 THEN returnvalue1
WHEN value2 THEN returnvalue2
WHEN value3 THEN returnvalue3
……
ELSE defaultreturnvalue
END
例子:

SELECT
    t.NAME,
    (
        CASE t.sex
        WHEN 1 THEN
            '男'
        WHEN 2 THEN
            '女'
        ELSE
            '未知'
        END
    ) 性别
FROM
    t_customer t
用法二:

CASE
WHEN condition1 THEN returnvalue1
WHEN condition 2 THEN returnvalue2
WHEN condition 3 THEN returnvalue3
……
ELSE defaultreturnvalue
END
例子:

SELECT
    t.NAME,
    (
        CASE 
        WHEN t.sex=1 THEN
            '男'
        WHEN t.sex=2 THEN
            '女'
        ELSE
            '未知'
        END
    ) 性别
FROM
    t_customer t

方式二: IF()函数

使用CASE函数可以实现非常复杂的逻辑判断,可是若只是实现“如果符合条件则返回A,否则返回B”这样简单的判断逻辑的话,使用CASE函数就过于繁琐。MYSQL提供了IF()函数用于简化这种逻辑判断,其语法格式如下:IF(expr1,expr2,expr3)

如果 expr1 为真(expr1 <> 0 以及 expr1 <> NULL),那么 IF() 返回 expr2,否则返回expr3。IF()返回一个数字或字符串,这取决于它被使用的语境。
例子:

select t.name,if(t.weight<80,‘正常’,‘肥胖’) 体重 from t_customer t

感觉这个作用和oracle 的nvl函数类似

mysql还有一个IFNULL(value1,value2)函数,这个函数一般用来替换 NULL 值的,我们知道 NULL 值是不能参与数值运算的,比如把emp员工表的员工的提成给加100,可以这么干:

update emp set comm = IFNULL(comm,0)+100,这样就把提成comm为null的替换成了0,从而不会出现null+100=null。

方式三 : IF-THEN-ELSE语句通常用在根据不同条件执行不同SQL的场景。

ELSEIF 可选,按顺序执行判断条件,当结果为true时,执行其中的子句
ELSE 可选,当前面的条件都不为true时,执行其中的子句

例子

DELIMITER //
CREATE FUNCTION IncomeLevel ( monthly_value INT )
RETURNS varchar(20)
BEGIN
DECLARE income_level varchar(20);
IF monthly_value <= 4000 THEN
SET income_level = 'Low Income';
ELSEIF monthly_value > 4000 AND monthly_value <= 7000  THEN
SET income_level = 'Avg Income';
ELSE
SET income_level = 'High Income';
END IF;
RETURN income_level;
END; //
DELIMITER ;

IF 判断条件 THEN
执行的语句
ELSEIF 子判断条件 THEN
执行语句
ELSE
执行语句
END IF; //结束语

方式四:字符串的集合操作ELT()

ELT(N,str1,str2,str3,…)

如果 N = 1,返回 str1,如果N = 2,返回 str2,等等。如果 N 小于 1 或大于参数的数量,返回 NULL。

例子:

SELECT
    t. NAME,
    ELT(
        t. LEVEL,
        '超级VIP',
        'VIP',
        '普通'
    ) 客户类型
FROM
    t_customer t
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值