mysql 中 isnull 和 ifnull 判断字段是否为null
2016-02-19 11:30
585 查看
对于统计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;
就好了,就这样。
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之锁
- MySQL主从搭建
- 古诗MySQL数据库中使用到的DAO模式
- mysql之——存储过程 + 游标 + 事务
- Mysql各种索引区别
- mySQL 开启事件存储过程
- index condition pushdown(icp)---mysql5.6新功能
- mysql中文乱码问题
- mysql 查看 删除 日志操作总结(包括单独和主从mysql)
- MySQL服务器权限表
- MySQL数据处理函数
- MySQL各个版本的区别
- MySQL查看数据库信息
- mysql事物隔离级别
- 转 Cobar使用文档(可用作MySQL大型集群解决方案)
- Mysql中字符串正确的连接方法
- 两主机搭建MySQL主从复制后,show slave status显示:Last_IO_Error: error connecting to master ……
- 解决MySQL安装版出现the the service mysql57 failed问题的方法。
- 关于MySQL修改密码的问题
- You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version