mysql的逻辑函数_MySQL常用逻辑函数

IFNULL(expression, alt_value)

判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个

参数的值。

示例:

mysql> select ifnull(comm,0)

-> from emp;

+----------------+

| ifnull(comm,0) |

+----------------+

| 0 |

| 300 |

| 500 |

| 0 |

| 1400 |

| 0 |

| 0 |

| 0 |

| 0 |

| 0 |

| 0 |

| 0 |

| 0 |

| 0 |

+----------------+

IF(expr1,expr2,expr3)

如果expr1的值为true,则返回expr2的值,如果expr1的值为false,则返回expr3的值。

示例:

mysql> select ename,sal,if(sal>=3000,'高',if(sal>=1500,'中','低')) 工资级别

-> from emp;

+--------+------+--------------+

| ename | sal | 工资级别 |

+--------+------+--------------+

| smith | 800 | 低 |

| allen | 1600 | 中 |

| ward | 1250 | 低 |

| jones | 2975 | 中 |

| martin | 1250 | 低 |

| blake | 2850 | 中 |

| clark | 2450 | 中 |

| scott | 3000 | 高 |

| king | 5000 | 高 |

| turner | 1500 | 中 |

| adams | 1100 | 低 |

| james | 950 | 低 |

| ford | 3000 | 高 |

| miller | 1300 | 低 |

+--------+------+--------------+

CASE WHEN expr1 THEN expr2 [WHEN expr3 THEN expr4...ELSE expr] END

如果expr1的值为true,则返回expr2的值,如果expr3的值为false,则返回expr4的值...

示例:

mysql> select ename,sal,case when sal>=3000 then '高' when sal>=1500 then '中'

else '低' end 工资级别

-> from emp;

+--------+------+--------------+

| ename | sal | 工资级别 |

+--------+------+--------------+

| smith | 800 | 低 |

| allen | 1600 | 中 |

| ward | 1250 | 低 |

| jones | 2975 | 中 |

| martin | 1250 | 低 |

| blake | 2850 | 中 |

| clark | 2450 | 中 |

| scott | 3000 | 高 |

| king | 5000 | 高 |

| turner | 1500 | 中 |

| adams | 1100 | 低 |

| james | 950 | 低 |

| ford | 3000 | 高 |

| miller | 1300 | 低 |

+--------+------+--------------+

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值