`

mysql中的if,ifnull函数

 
阅读更多
MySQL ifnull()函数和nvl()函数类似,但是也有所不同,下面就为您详细介绍MySQL ifnull()函数 ,希望可以让您对MySQL ifnull()函数有更深的认识。

IFNULL(expr1,expr2)
如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2。IFNULL()返回一个数字或字符串值,取决于它被使用的上下文环境。
mysql> select IFNULL(1,0);
        -> 1
mysql> select IFNULL(0,10);
        -> 0
mysql> select IFNULL(1/0,10);
        -> 10
mysql> select IFNULL(1/0,'yes');
        -> 'yes'

IF(expr1,expr2,expr3)
如果expr1是TRUE(expr1<>0且expr1<>NULL),那么IF()返回expr2,否则它返回expr3。IF()返回一个数字或字符串值,取决于它被使用的上下文。
mysql> select IF(1>2,2,3);
        -> 3
mysql> select IF(1<2,'yes','no');
        -> 'yes'
mysql> select IF(strcmp('test','test1'),'yes','no');
        -> 'no'

expr1作为整数值被计算,它意味着如果你正在测试浮点或字符串值,你应该使用一个比较操作来做。

mysql> select IF(0.1,1,0);
        -> 0
mysql> select IF(0.1<>0,1,0);
        -> 1

在上面的第一种情况中,IF(0.1)返回0,因为0.1被变换到整数值, 导致测试IF(0)。这可能不是你期望的。在第二种情况中,比较测试原来的浮点值看它是否是非零,比较的结果被用作一个整数。
分享到:
评论

相关推荐

    PostgreSQL IF/IFNULL 函数 内核开发

    1. 博客:PostgreSQL的学习心得和知识总结(六十七)|语法级自上而下完美实现MySQL数据库的 IF函数和IFNULL函数 的实现方案

    浅谈Mysql中类似于nvl()函数的ifnull()函数

    mysql&gt; select IFNULL(1,0); -&gt; 1 mysql&gt; select IFNULL(0,10); -&gt; 0 mysql&gt; select IFNULL(1/0,10); -&gt; 10 mysql&gt; select IFNULL(1/0,'yes'); -&gt; 'yes' IF(expr1,expr2,expr3) 如果expr1是TRUE(expr1&lt;&gt;0

    mysql函数ifnull在pg 9.6中的实现

    工作中迁移mysql至pg 9.6,遇到mysql中的ifnull函数在pg中没有,pg中函数coalesce与ifnull功能相同,但函数名不同,需要修改应用。ifnull也在SQL标准中,pg此处不符合sql标准规范。本人尝试修改pg源码添加了ifnull...

    浅谈SQLServer的ISNULL函数与Mysql的IFNULL函数用法详解

    **MySQL的IFNULL函数** 在MySQL中,处理NULL值的函数是`IFNULL`,它的工作原理类似,但语法稍有不同: ```sql IFNULL(expr1, expr2) ``` 1. **expr1**:这是第一个表达式,如果它不是NULL,`IFNULL`将返回expr1的...

    浅谈Mysql中类似于nvl()函数的ifnull()函数.pdf

    浅谈Mysql中类似于nvl()函数的ifnull()函数 IFNULL()函数是Mysql中一个非常有用的函数,它可以用来检查...IFNULL()、IF()和CASE函数都是Mysql中非常有用的函数,它们可以用来实现各种复杂的逻辑运算和条件判断。

    MySql中的IFNULL、NULLIF和ISNULL用法详解

    本文将详细介绍MySQL中的`IFNULL`、`NULLIF`和`ISNULL`这三个函数的用法。 1. `ISNULL()`函数: `ISNULL(expr)`用于检查表达式`expr`是否为NULL。如果`expr`是NULL,`ISNULL()`返回1,否则返回0。它与`expr IS ...

    mysql函数大全,mysql

    STRCMP STRCMP()函数是MySQL里比较字符串的最简单方式之一。这个函数接受两个参数——要被比较的字符串。如果这个两个字符串相同,它就返回0;如果第一个大于第二个,它就返回1;如果第一个小于第二个,它就返回-1 ...

    mysql实现if语句判断功能的六种使用形式

    1. **IFNULL函数** IFNULL函数用于检测一个表达式是否为NULL。如果表达式为NULL,IFNULL会返回第二个参数的值;否则,返回第一个参数的值。例如: - 当`expression_1`为空时,`SELECT IFNULL(NULL, 'a')`将返回'a'...

    mysql常用函数汇总.chm

    Mysql的常用函数整体, 从网上收集的一些常用函数, 进行汇总整体成文档 MySQL控制流函数: CASE WHEN[test1] THEN [result1]...ELSE [default] END如果testN是真,则返回resultN,否则返回default CASE [test] WHEN...

    MySQL里的IFNULL、NULLIF和ISNULL用法

     mysql中isnull,ifnull,nullif的用法如下:  isnull(expr) 的用法:如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。mysql&gt; select isnull(1+1);-&gt; 0mysql&gt; select isnull(1/0);-&gt; 1使用= 的null ...

    mysql中IFNULL,IF,CASE的区别介绍

    在MySQL数据库中,`IFNULL`, `IF`, 和 `CASE` 都是用来处理逻辑和条件判断的函数,但它们有着不同的用法和适用场景。理解它们的区别对于编写更高效的SQL查询至关重要。 首先,`IFNULL` 函数是最简单的,它的主要...

    MySQL函数大全中文版

    5. **条件函数**:如`IF()`、`IFNULL()`和`COALESCE()`允许在SQL语句中进行条件判断,返回不同结果。 6. **控制流程函数**:如`CASE`语句用于创建复杂的条件表达式,`LEAST()`和`GREATEST()`用于找出最小或最大的值...

    MySql函数详解!!!

    字符串函数:字符串函数是MySQL中最常用的一类函数,字符串函数主要用于处理表中的字符串。 日期和时间函数:MySQL的日期和时间函数主要用于处理日期时间。 条件判断函数: 1、IF(expr,v1,v2)函数 如果表达式expr...

    SQL Server 和 MySql 语法和关键字的区别——用于SQLServer到MySql的转换

    在 SQL Server 中,IFNULL 函数用于返回第一个参数不为空的值,而在 MySql 中,IFNULL 函数被称为 ISNULL 函数。例如,在 SQL Server 中,我们可以使用 IFNULL 函数来返回一个默认值,如果某个字段为空的话:`SELECT...

    MySQL数据库函数,触发器,存储过程

    MySQL提供了丰富的内置函数,包括数值函数(如ABS、SQRT)、字符串函数(如CONCAT、SUBSTRING)、日期和时间函数(如NOW、DATE_ADD)以及一些通用函数(如IFNULL、COUNT)。这些函数可以简化SQL查询,提高代码可读性...

    mysql中替代null的IFNULL()与COALESCE()函数详解

    在MySQL中isnull()函数不能作为替代null值! 如下: 首先有个名字为business的表: SELECT ISNULL(business_name,'no business_name') AS bus_isnull FROM business WHERE id=2 直接运行就会报错: 错误代码...

Global site tag (gtag.js) - Google Analytics