0
点赞
收藏
分享

微信扫一扫

mysql函数汇总之条件判断函数

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

IF(expr,v1,v2)函数

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

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()​​的返回值是数字或者字符串,具体情况取决于其所在的语境。

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​​。

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​​表达式的默认返回值类型是任何返回值的相容集合类型,但具体情况视其所在语境而定。

至此,本文结束。 

更多内容请转至VX公众号 “运维家” ,获取最新文章。


------ “运维家”  ------


------ “运维家”  ------


------ “运维家”  ------


linux中断异常,linuxuml建模,linux编译多个源文件,linux怎么更新时间,linux中的分页视频教程,

linux怎么解压gzip,linux解压某个目录,怎么关闭linux网关,linux文件架构图,linux提高权限执行,

linux文件用什么标志,网络安全linux加固,linux中查看邮件,linux修改背景颜色,linux环境下搭建网站。


举报

相关推荐

0 条评论