MySQL讲解条件判断函数


本文摘自PHP中文网,作者coldplay.xixi,侵删。

函数:

(1)IF(expr,v1,v2)函数
(2)IFNULL(v1,v2)函数
(3)CASE函数

(相关免费学习推荐:mysql视频教程)

(1)if(expr,v1,v2)函数
  • 在if(expr,v1,v2)函数中,若表达式expr是true(expr<>0 and epr<>null)返回v1,否则返回v2。

【例】使用if()函数进行条件判断,SQL语句如下:

1

2

3

mysql> select if(1>2,2,3),

    -> if(1<2,'yes','no'),

    -> if(strcmp('test','test1'),'no','yes');+-------------+--------------------+---------------------------------------+| if(1>2,2,3) | if(1<2,'yes','no') | if(strcmp('test','test1'),'no','yes') |+-------------+--------------------+---------------------------------------+|           3 | yes                | no                                    |+-------------+--------------------+---------------------------------------+1 row in set (0.00 sec)


(2)ifnull(v1,v2)函数
  • 在ifnull(v1,v2)中,假如v1不为null,则ifnull()的返回值为v1,否则返回值为v2。
  • 如果v1或v2中只有一个明确是null,则if()函数的结果类型为非null表达式的结果类型。

【例】使用ifnull()函数进行条件判断,SQL语句如下:

1

mysql> select ifnull(1,2),ifnull(null,10),ifnull(1/0,'wrong');+-------------+-----------------+---------------------+| ifnull(1,2) | ifnull(null,10) | ifnull(1/0,'wrong') |+-------------+-----------------+---------------------+|           1 |              10 | wrong               |+-------------+-----------------+---------------------+1 row in set (0.00 sec)


(3)case函数

1.case expr when v1 then r1 [ when v2 then r2] [else rn] end

  • 该函数表示,如果expr值等于某个vi,则返回对应位置then后面的结果,如果与所有值都不相等,则返回else后面的m。

【例】使用case value when语句执行分支操作,SQL语句如下;

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)

2.case when v1 then rv [when v2 then r2] else rn] end

  • 该函数表示,某个vi值为true时,返回对应位置then后面的结果,如果所有值都不为true,则返回else后面的rn。
  • 一个case表达式的默认返回值类型是任何返回值的相容集合类型,具体情况视其所在语境而定。

【例】使用case when 语句执行分支操作,SQL语句如下:

1

mysql> select case when 1<0 then 'true' else 'false' end;+--------------------------------------------+| case when 1<0 then 'true' else 'false' end |+--------------------------------------------+| false                                      |+--------------------------------------------+1 row in set (0.00 sec)

更多相关免费学习推荐:mysql教程(视频)

以上就是MySQL讲解条件判断函数的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

phpmyadmin怎么批量导入excel数据到mysql

mysql加密函数有哪些?

mysql如何取消错误命令?

mysql如何输出汉字信息

linux mysql5.6版本的安装配置过程

mysql中各种常见join连表查询实例总结

mysql怎么添加汉字

mysql innodb 事务锁源码分析

mysql5.7.33安装过程图文详解

centos 6.5下 mysql-community-server. 5.7.18-1.el6安装

更多相关阅读请进入《mysql》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...

    正在狠努力加载,请稍候...