MySQL Join操作浅析



一、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算法。



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值