一、Join操作的类型&条件
类型:内连接(inner join),外连接(left outer join, right outer join, full outer join)
条件:natural(自然连接)
二、准备
准备三章表:stu_baseinfo表示学生基本信息,stu_course表示学生选课信息,stu_tutor表示学生导师信息
可以通过下面的连接就行下载无须积分,然后启动mysql,输入source file就可以了(sql文件的路径要正确)
stu_baseino表数据如下
stu_course表数据如下
stu_tutor表数据如下
三、各种Join操作分析(所有实验均在mysql5.6进行)
3.1 join ,inner join, cross join
在MySQL中三者意义一样,就是简单的做笛卡尔积。
PS:令我不解的是select * from stu_baseinfo abcd join stu_course on stu_baseinfo.id=stu_course.id;
无论在join前面加什么字符串即使是abcd,不知道这是一个bug还是有意的。
3.2 left outer join:左外连接
A left outer join B on condition 就是将满足条件的行选出来同时将A中不满足条件的行自然落下,没有的属性用NULL补
其中outer可以省略不写在MySQL中
3.3 right outer join
右外连接 A right outer join B on condition = B left outer join A on condition
MySQL不支持全外连接,可以先做左外连接再做右外连接然后将二者做union操作模拟全外连接
3.4 using 与 natural自然连接
using的用法与on类似都是连接的条件,using后面的属性必须是join表共有的属性
PS:一定不要忘记using后面的属性要写括号
不知道细心的你有没有发现用using与自然连接的id只显示一列,而上面使用on的左外与右外连接以及内连接id都重复显示,这就是他们之间的区别。
3.5 ‘,’逗号操作符与join
mysql中逗号操作符于join是一致的,但是逗号操作符的优先级要低于join。
即:t1 ,t2 join t3 的执行顺序是t2 join t3 然后结果跟t1 join 。
下面用mysql的explain简答分析一下二者的关系
从上面结果中可以看出,join操作的on等同于where子句,逗号操作符与join一样。
从结果中还可以看出在mysql执行查询的过程中使用了join buffer优化技术采用的是block nested loop算法。