mysql条件判断函数的使用介绍

149 篇文章 2 订阅

本文主要介绍了mysql条件判断函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

条件判断函数也被称为控制流程函数,根据满足的不同条件,执行响应的流程。mysql中进行条件判断的函数有if、ifunll和case等。

IF(expr,v1,v2)函数

IF(expr,v1,v2):如果表达式expr是TRUE(expr <> 0 and expr <> null),则返回值为V1;否则返回值为V2。

1

2

3

4

5

6

7

8

9

mysql> select if (1>2, 2, 3), if (1<2, 'yes', 'no');

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

| if (1>2, 2, 3) | if (1<2, 'yes', 'no') |

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

|              3 | yes                   |

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

1 row in set (0.00 sec)

mysql>

小提示:

如果V1或者V2中只有一个明确是null,则if()函数的结果类型为非null表达式的结果类型。

IFNULL(v1,v2)函数

ifnull(v1,v2):假如V1不为null,则ifnull()的返回值为v1;否则其返回值为v2。

ifnull()的返回值是数字或者字符串,具体情况取决于其所在的语境。

1

2

3

4

5

6

7

8

9

mysql> select ifnull(1, 2), ifnull(null, 'yunweijia'), ifnull(1/0, 'heihei');

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

| ifnull(1, 2) | ifnull(null, 'yunweijia') | ifnull(1/0, 'heihei') |

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

|            1 | yunweijia                 | heihei                |

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

1 row in set (0.00 sec)

mysql>

CASE函数

case expr when v1 then r1 [when v2 then 2]...[else rn+1]end:如果expr值等于某个vn,则返回对应位置then后面的结果;如果与所有值都不相等,则返回else后面的rn+1。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

mysql> select case 2 when 1 then 'one' when '2' then 'two' else 'more' end;

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

| case 2 when 1 then 'one' when '2' then 'two' else 'more' end |

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

| two                                                          |

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

1 row in set (0.00 sec)

mysql>

mysql> select case 5 when 1 then 'one' when '2' then 'two' else 'more' end;

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

| case 5 when 1 then 'one' when '2' then 'two' else 'more' end |

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

| more                                                         |

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

1 row in set (0.00 sec)

mysql>

 小提示:

可以按照shell中的if语句来理解。

一个case表达式的默认返回值类型是任何返回值的相容集合类型,但具体情况视其所在语境而定。

到此这篇关于mysql条件判断函数的具体使用的文章就介绍到这了,更多

转自:微点阅读   https://www.weidianyuedu.com

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值