mysql返回null值怎么办?

原文链接:这里
0.前言

跑代码的时候,后台有时候会返回null,然后需要在代码里判断是否为空,比较麻烦。如果在sql层就能保证数据不为空那么在代码中就不需要加以判断了。

1.解决办法

这个地方主要用isnull和ifnull方法。先说下区别,防止误用。

ISNULL(expr) 用法: 如expr 为null,那么isnull() 的返回值为 1,否则返回值为 0。 

IFNULL(expr1,expr2)用法:

      假如expr1不为NULL,则 IFNULL() 的返回值为expr1; 否则其返回值为 expr2。IFNULL()的返回值是数字或是字符串,具体情况取决于其所使用的语境。

3.问题

下面的sql还是会返回null。不知道为什么

SELECT IFNULL(orderNo,0) as orderNo from law
WHERE type='2'
and id ='9d3d58bd'

百思不得其解,但是,还是找到了解决办法。

写成子查询就行了。

SELECT
IFNULL( ( SELECT orderNo FROM law WHERE type = '3' AND id = '9d3d58b' ), 0 ) AS orderNo;

像上面那样就可以了。

posted on   longkui  阅读(528)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示