SQL查询之区分内连接和外连接的使用场景

学习完sql语言之后,自己去做练习的时候出现这种情况:

我做的题目答案这样:

-- 查询学过编号为"01"并且也学过编号为"02"的课程的同学的信息
select * from student st
left join score sc on st.s_id=sc.s_id
left join course c on sc.c_id=c.c_id
where c.c_id='01' and c.c_id='02';

而别人的答案却长这样

select * from student st 
inner join score sc on sc.s_id = st.s_id
inner join course c on c.c_id=sc.c_id and c.c_id="01"
where st.s_id in (
select st2.s_id from student st2 
inner join score sc2 on sc2.s_id = st2.s_id
inner join course c2 on c2.c_id=sc2.c_id and c2.c_id="02"
)

可以发现自己使用的是左外连接,而答案使用的是内连接。那么就有疑惑了,到底谁对谁错呢?以及如何区分何时使用内连接,何时使用外连接?

  • 明确题目查询内容?是需查找两张表同时存在的数据,还是需要查一张表中存在一张表中不存在的数据?

举例:现有一张学生表student(S),一张选课表couse(C),学生选修了多门科目导致S与C表之间的关系是一对多,

使用内连接:select s.* from S s,C c where s._id=c.s_id;

此时结果是student在course表中有子数据的部分数据,如果S表在C表中不存在对应的子数据,那么该查询语句是查不出来的。

所以总结如下:如查找两张表同时存在的数据,用内连接;如需筛选的是一张表存在另一张表不存的数据可使用外连接(包含左外连接和右外连接)

注:

inner join  on :最终查询结果>=0

left    join  on :如果存在不满足on条件的结果,则左表仍有对应记录,右边结果以null标识,最终查询结果>=左表的记录数

right    join  on :如果存在不满足on条件的结果,则右表仍有对应记录,左表结果以null标识,最终查询结果>=右表的记录数

个人理解,欢迎补充~


感谢评论区的指正让我解惑了。
我的语句确实是查不出结果的。
答案的语句先查出学习了02课程的学生id,然后查出学习了01课程的学生id,最后用in对选择01又选择了02课程的结果进行筛选

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值