搞懂mysql中join的七种sql的编写

表的准备:

员工表:emp表(A表)

部门表:dept表(B表)

第一种:内连接

sql语句:SELECT * FROM emp a INNER JOIN dept b ON a.deptno=b.deptno

 查询结果:

 结论:就是把两者共有的部分查出来

第二种:左外连接

 

sql语句:SELECT * FROM emp a left JOIN dept b ON a.deptno=b.deptno

 查询结果:

结论:主要是查A表,如果B中有满足条件的就查出来,没有就用null填充

第三种:右外连接

sql语句:SELECT * FROM emp a right JOIN dept b ON a.deptno=b.deptno

 查询结果:

结论:主要查B表,如果A表中有满足条件的就查出来,没有就用null来填充

第四种:左连接

 sql语句:SELECT * FROM emp a LEFT JOIN dept b ON a.deptno=b.deptno WHERE b.deptno IS null 

查询结果:

结论:查出A,B两张表中A独有的数据

第五种:右连接

 

 sql语句:SELECT * FROM emp a Right JOIN dept b ON a.deptno=b.deptno WHERE a.empno IS null

 查询结果:

结论:查出A,B两张表中B独有的数据

第六种:全连接

  sql语句:

select * from emp a left join dept b on a.deptno = b.deptno       (找出A表的所有数据)

union    (连接并去重)

select * from emp a right join dept b on a.deptno = b.deptno   (找出B表的所有数据)


查询结果: 

结论:找出A表和B表的所有数据(A表的独有和B表的独有以及A,B表公有的部分)

第七种:全外连接

sql语句:

SELECT * FROM emp a LEFT JOIN dept b ON a.deptno = b.deptno WHERE b.deptno IS NULL      (找出A表中独有的数据)

UNION      (连接)

SELECT * FROM emp a RIGHT JOIN dept b ON a.deptno = b.deptno WHERE a.deptno IS NULL     (找出B表中独有的数据)

查询结果:

结论:找出A表和B表的中各自独有的数据

结束!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值