mysql - SQL查询问题
问题描述
表A 表Buser_id name id user_id sorce 1张三 1 1 78 2李四 2 2 3王五 3 5 80 想要查询表A中 没有分数或者表B中没有分数记录的,sql如何写?select A.user_idid A.name FROM A LEFI JOIN BON A.user_id=B.user_id WHERE B.sorce=’’;这个SQL不知道对不对?1.表A中的user_id=3的王五,但王五的记录在B表中没有,我用左链接查询出来2.sorce =’’解决分数为空 查询出来
问题解答
回答1:不太同意一楼的sql语句,第一是因为子查询,第二好像没有检索出没有分数记录的。
SELECT * FROM product.a left join product.b on aid=aid2 where b.aid2 is null or sc is null;
这是我自己本地测试的,用的是mysql,但是其实都差不多。先用表连接把两个表按照规定的id链接在一起,aid对应是你a表里的userid,aid2对应是你b表的userid,然后最后上图。图一是我的sql语句的结果,图二是我的a表,图三是我的b表。



这也只是解决的一种方式,我也不是很擅长后台数据库~~希望对你有帮助,也希望有更好的解决方案。因为我没有考虑性能问题。
回答2:select * from 表A where user_id not in (select user_id from 表B where score >=0 )回答3:
select user_id, namefrom table_a where user_id not in (select user_id from table_b)union allselect b.user_id, a.namefrom table_b binner join table_a a on a.user_id = b.user_idwhere b.sorce=’’
有时候判断条件语句过于复杂可以使用union all将各个条件结果连接在一起.
相关文章:
1. docker网络端口映射,没有方便点的操作方法么?2. angular.js - 在angular中,使用ng-repeat循环输出一个列表,然后节当中具体的一个参数值(是数值),然后整个循环节的值总数相加3. nginx - 关于vue项目部署到ngnix后出现的问题4. python - Fiddler+Android模拟器抓取app,json数据被加密了,如何解析?5. angular.js - $emit(,)的具体意思是什么作用呢?6. docker-compose 为何找不到配置文件?7. javascript - vue使用keep-alive不能保持滚动位置问题。8. MySQL的SELECT...FOR UPDATE究竟起什么作用9. javascript - 一个字符串转换成数字,例子就是a="2,322.222",b=’1,211.21’,如何在angualr中执行相减10. PHP中的$this代表当前的类还是方法?

 网公网安备
网公网安备