mysql select isnull_mysql数据库 isnull,ifnull,nullif的区别和用法

ISNULL(expr)

如果expr的值为null,则返回1,如果不为null,则返回0;

例如,查找一个订单的状态,如果状态为null则返回1,不为空则返回0

select isnull(status) from orders;

查出的数据

27b6d5aad316f4e208bd33e804aa8a8d.png

IFNULL(expr1,expr2)

如果expr1不为NULL,则返回expr1; 否则返回expr2。

IFNULL()的返回值是数字或是字符串.

例如查询所有商品,把价格为null的改为0;

select ifnull(goods_price,0) from goods ;

1a2ce2301c2af115f0261431c6dde2d1.png

则返回所有商品价格,如果有null的则返回0;

NULLIF(expr1,expr2)

如果expr1和expr2相等,则返回null,否则返回expr1的值

例如

查询商品的促销价格和市场价格是否相等,不相等返回促销价格,相等则返回null

select nullif(goods_price,goods_marketprice) from goods;

当然,一般情况下相等也不返回null,这只是个实例;

本文为仙士可原创文章,转载无需和我联系,但请注明来自仙士可博客www.php20.cn

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值