SQL 连接(内连接,外连接)

内连接

现在有两张表,学生表student1,成绩表SC1,两张表的数据如下

SQL 连接(内连接,外连接)

现在要对两张表做连接查询,连接一般需要写条件,where 或者 on 后面 ,

select * from student,SC where student.sid=SC.sid   from 后面直接写两个表名,这样写等价于内连接 如果不写 where 条件,相当于笛卡尔积。

SQL 连接(内连接,外连接)

带有 where 条件 相当于内连接

SQL 连接(内连接,外连接)

A(inner,left,right) join B on A.1=B.1   on 不写会报错
select * from student inner join SC on student.sid=SC.sid

外连接(左外连接,右外链接)

左联接,是包括 A,B 表的交集 和 A 表的数据 (A eft join B on A.1=B.1),如果 A 表中有的数据 B 表没有找到相等的,会显示A表的数据,B表中的部分会为 null ,下面的结果就是成绩表中没有赵六和田七的数据的结果

SQL 连接(内连接,外连接)

如果 and 写在 on 后面,表示的是在做关联时不关联被过滤掉的数据,比如上面的数据,写 and sc.score>60 条件之后,会过滤掉成绩<=60的数据,而张三丰每一门课的成绩都小于60,但是会有张三丰的数据,只是后面的为null,如下:

SQL 连接(内连接,外连接)

上面的数据是过滤掉成绩小于60的数据之后,张三丰的成绩都小于60,并不是没有张三丰这个数据了,而是他后面的为null,可以这样理解,on 后面的 and 条件是代表关联与否,不满足就不关联,但A表的数据还是要全部都有的。

如果成绩>60是写在where 里的,where 是对结果进行过滤的,所以会把上面的结果不满足成绩>60的数据过滤掉,即:

SQL 连接(内连接,外连接)

右外链接,同左外链接一样,包括并集和B表的数据。

学生表和成绩表做又外连接的时候,成绩表中有一条 1008 的数据在学生表中没有,结果如下:

SQL 连接(内连接,外连接)

对上面的结果进行 成绩 >60 的条件过滤

SQL 连接(内连接,外连接)

SQL 连接(内连接,外连接)

可以看到写在 on 后 和 where 后结果是不同的,可以理解为,写在 on 后面的条件如果不满足就不和另外一个表进行关联,但是他的数据还是会在结果中显示。对于要显示全部数据的那张表。

自连接,在这里就先不说了。以后再说。

上一篇:Android开发 MediaPlayer播放本地视频完善的demo(只是代码记录)


下一篇:Python并发编程二(多线程、协程、IO模型)