Join的几种类型

笛卡尔积(交叉连接)

如果A表有n条记录,B表有m条记录,笛卡尔积产生的结果就会产生n*m条记录
在MySQL中可以为CROSS JOIN或者省略CROSS即JOIN,或者直接用from多表用逗号分开。

SELECT * FROM table1 CROSS JOIN table2
SELECT * FROM table1 JOIN table2
SELECT * FROM table1 , table2

不用on table1.key1 = table2.key2 得出的结果是table1的记录数*table2的记录数,如果用on连接,得出的和inner join的结果一样(所以在有on的情况下,inner joijn、cross join、 join(推荐、会自动用小的表作为驱动表)结果一样)。

内连接:INNER JOIN

内连接INNER JOIN是最常用的连接操作。从数学的角度讲就是求两个表的交集,从笛卡尔积的角度讲就是从笛卡尔积中挑出ON子句条件成立的记录。有INNER JOIN,WHERE(等值连接),STRAIGHT_JOIN,JOIN(省略INNER)四种写法。

左【外】连接:LEFT [out] JOIN

左连接LEFT JOIN的含义就是求两个表的交集外加左表剩下的数据。依旧从笛卡尔积的角度讲,就是先从笛卡尔积中挑出ON子句条件成立的记录,然后加上左表中剩余的记录(见最后三条)。

右【外】连接:RIGHT [out] JOIN

同理右连接RIGHT JOIN就是求两个表的交集外加右表剩下的数据。再次从笛卡尔积的角度描述,右连接就是从笛卡尔积中挑出ON子句条件成立的记录,然后加上右表中剩余的记录(见最后一条)。

全外连接:Full outer join

产生A和B的并集。对于没有匹配的记录,则以null做为值。(注意!!!Orcal有,Mysql是没有全外连接的!!!可以用做外连接和右外连接在union(union连接的是两个查询不是两张表)起来)
select *,if(a.date is null,b.date,a.date) as date from a left join b on a.date = b.date  -- 只有a的全部
union -- union上面的复制下来left改为right,连个表头要一致
select *,if(a.date is null,b.date,a.date) as date from a right join b on a.date = b.date

查询存在于一张表不存在于另一张表的sql

select ta.* from ta where ta.id not in(select tb.id from tb)  /*效率低*/
select ta.id from ta left join tb on ta.id=tb.id where tb.id is NULL /*优化*/

两表JOIN优化

     a.当无order by条件时,根据实际情况,使用left/right/inner join即可,根据explain优化 ;
     b.当有order by条件时,如select * from a inner join b where 1=1 and other condition order by a.col;使用explain解释语句;
     1)如果第一行的驱动表为a,则效率会非常高,无需优化;
     2)否则,因为只能对驱动表字段直接排序的缘故,会出现using temporary,所以此时需要使用STRAIGHT_JOIN明确a为驱动表,来达到使用a.col上index的优化目的;或者使用left join且Where条件中不含b的过滤条件,此时的结果集为a的全集,而STRAIGHT_JOIN为inner join且使用a作为驱动表

最新文章

  1. php杂记(二)
  2. 异常处理的解决方案 OneTrueError
  3. SQL Server自动化运维系列——监控跑批Job运行状态(Power Shell)
  4. 使用Memcache缓存mysql数据库操作的原理和缓存过程浅析
  5. Loadrunner中参数化实战(1)-Sequential+Each iteration
  6. execute连接 类型
  7. ios 网络字节顺序的转换HTOS
  8. Android(java)学习笔记203:网页源码查看器(Handler消息机制)
  9. ABAP函数:VIEW_MAINTENANCE_CALL(维护表视图等)
  10. 【JAVA零基础入门系列】Day15 对象的比较
  11. Java 实现 HttpClients+jsoup,Jsoup,htmlunit,Headless Chrome 爬虫抓取数据
  12. echo -n 和echo -e 参数意义
  13. Python while for if....else
  14. python面试题(一)
  15. FastDFS初步认识--上传下载流程介绍
  16. Confluence 6 为空间赋予公共访问
  17. vue深入了解组件——自定义事件
  18. C# 简单Tcp通信demo
  19. mysql四-1:单表查询
  20. (数据科学学习手札45)Scala基础知识

热门文章

  1. P2860 [USACO06JAN]冗余路径Redundant Paths tarjan
  2. dll注入到指定进程
  3. .net Core 2.1 后 Session保存,新页面获取不到值
  4. P3412 仓鼠找sugar II
  5. p3792 由乃与大母神原型和偶像崇拜(思维+线段树)
  6. QLineEdit响应回车时避免Button同时响应
  7. DIV+CSS+PS实现背景图的三层嵌套以及背景图的合并
  8. Mysql视图、触发器、事务、储存过程、函数
  9. 51nod 1055 最长等差数列
  10. 那些年我们一起用过的 PHP 函数(一)