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()运行速度的比较