mysql 中 isnull 和 ifnull 判断字段是否为null

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql 中 isnull 和 ifnull 判断字段是否为null相关的知识,希望对你有一定的参考价值。

对于统计count(type)和avg(type) 都不起作用

SQL中有ISNULL方法,介绍如下:

ISNULL
使用指定的替换值替换 NULL。

语法
ISNULL ( check_expression , replacement_value )

参数

check_expression
将被检查是否为 NULL的表达式。check_expression 可以是任何类型的。
replacement_value
在 check_expression 为 NULL时将返回的表达式。replacement_value 必须与 check_expresssion 具有相同的类型。

例如:

SELECT count(ISNULL(Weight, 50))  FROM  Product;

但是在mysql中,isnull只是用来判断是否为空,不能实现替换功能,照上面写的话,会直接报错(Incorrect parameter count in the call to native function ‘isnull‘ Errornumber:1582 )。

那么Mysql中如何实现SQL中的ISNULL方法呢?IFNULL( check_expression , replacement_value ),实现了SQL中的ISNULL方法。

 还是上面的例子:

SELECT count(IFNULL(Weight, 50))  FROM  Product;

就好了,就这样。

以上是关于mysql 中 isnull 和 ifnull 判断字段是否为null的主要内容,如果未能解决你的问题,请参考以下文章

MySQL 的IFNULL()ISNULL()和NULLIF()函数

mysql几个常用的判空函数:isnull, ifnull, nullif, coalesce

MySQL-ISNULL()IFNULL()和NULLIF()函数

MySql数据库的优化 MySql中is NULLISNULL()和IFNULL()运行速度的比较

mysql 里面的isnull()和ifnull() is null 和 is not null

MySQLMySQL的IFNULL()ISNULL()NULLIF()函数用法说明