mysql - 这个SQL哪不对
问题描述
1.统计任务提交情况2.A(id,name)人员表,B(bid,aid, mission)任务提交记录表,aid 对应id,mission为字符串字段,一个人可提交多次任务,示例数据 id name 1 张三 2 李四 3 王五
bid aid mission1 1 xxxxx2 1 yyyyy3 2 zzzz
sql: select A.name,if(mission<>null,1,0) as mnum from A leftjion B on B.aid= A.id orderby id得到是name mnum张三 0张三 0李四 0王五 0
这个if怎么不起作用的????本来最终想得到如下效果,那么SQL怎么写name 任务次数张三 2李四 1王五 0
问题解答
回答1:这句亲测成功
select A.name,sum(if(mission is not null,1,0)) as ’任务次数’ from A leftjion B on B.aid= A.id group by A.id order by A.id desc回答2:
SELECT NULL IS NULL, NULL IS NOT NULL, NULL = NULL, NULL <> NULL你分别跑下 你就知道为什么你的if不起作用了。
回答3:按照SQL规范,所有和NULL运算的结果都是NULL,所以对NULL的判断需要使用特殊的方法
1、IFNULL函数2、mission<>null 改为 mession is not null
相关文章:
1. angular.js - 不适用其他构建工具,怎么搭建angular1项目2. python如何不改动文件的情况下修改文件的 修改日期3. mysql - 一个表和多个表是多对多的关系,该怎么设计4. javascript - git clone 下来的项目 想在本地运行 npm run install 报错5. mysql主从 - 请教下mysql 主动-被动模式的双主配置 和 主从配置在应用上有什么区别?6. android-studio - Android 动态壁纸LayoutParams问题7. 主从备份 - 跪求mysql 高可用主从方案8. angular.js - 三大框架react、vue、angular的分析9. python 如何实现PHP替换图片 链接10. python - django 里自定义的 login 方法,如何使用 login_required()
