mysql的ifnull函数在甚么条件下不能使用
1个回答
展开全部
你可以这样理解,mysql的执行顺序是from->where->select
经过where过滤之后才select来显示相应字段,如果where过滤完之后都没记录了,那select也就为null。(要想val为null就返回为0,除val字段外其余字段必须有一个不为null)
如果空表你也要返回0,可以在外面多嵌套一层
select ifnull(m.num,0) as num from (select IFNULL(val,0) AS num from t_type where type = '1')m
经过where过滤之后才select来显示相应字段,如果where过滤完之后都没记录了,那select也就为null。(要想val为null就返回为0,除val字段外其余字段必须有一个不为null)
如果空表你也要返回0,可以在外面多嵌套一层
select ifnull(m.num,0) as num from (select IFNULL(val,0) AS num from t_type where type = '1')m
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |