当前位置:网站首页>mysql函数汇总之条件判断函数
mysql函数汇总之条件判断函数
2022-07-26 08:11:00 【运维家】
条件判断函数也被称为控制流程函数,根据满足的不同条件,执行响应的流程。
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环境下搭建网站。
边栏推荐
猜你喜欢

JSP implicit object -- scope

Understand microservices bit by bit

Excel file parsing

Software engineering -- dental clinic -- demand analysis

NFS service and Samba service deployment

Rack server expansion memory

有点牛逼,一个月13万+

Traversal mode of list, set, map, queue, deque, stack

Burp Suite - Chapter 2 burp suite proxy and browser settings

FTP service
随机推荐
Use of views
Software engineering -- dental clinic -- demand acquisition
Summarize the common high-frequency interview questions of the software testing post
一点一点理解微服务
Sort sort IP addresses
[uniapp] encapsulation of multiple payment methods
Establishment and use of openstack cloud platform
Lnmp+wordpress to quickly build a personal website
Recurrence of strtus2 historical vulnerability
Stack simulation queue
This is a picture
Stm8 official library file download
咱就是来聊聊并发编程的三大核心问题。
分享高压超低噪声LDO测试结果(High Voltage Ultra-low Noise LDO)
Distributed system and distributed database system (Introduction)
Abstract classes and interfaces
【 fastjson1.2.24反序列化漏洞原理代码分析】
The difference between throw and throws?
Zroi easy sum (generating function, block, DP, combination, polynomial)
The difference between ArrayList and LinkedList