欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

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

程序员文章站 2022-05-12 15:59:25
...
数据库中经常有字段type为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;

就好了,就这样。