学习完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课程的结果进行筛选