MySQL基础表和数据

-- 5条数据
select * from test_a; -- 8条数据
select * from test_b;

内连接

-- 内连接,join,为inner join的简化写法,产生A和B的交集。条数=A和B匹配的条数=4<=max(A条数, B条数)
select * from test_a a join test_b b on a.name = b.name;

左外连接

-- 左外连接,left join,为left outer join的简化写法,产生表A的完全集,而B表中匹配的则有值,没匹配的以NULL值取代。条数=B中匹配A的条数+表A中未匹配的条数=4+3=7>=A表条数
select * from test_a a left join test_b b on a.name = b.name;

右外连接

-- 右外连接,right join,为right outer join的简化写法,产生表B的完全集,而A表中匹配的则有值,没匹配的以NULL值取代。条数=A中匹配B的条数+表B中未匹配的条数=4+4=8>=B表条数
select * from test_a a right join test_b b on a.name = b.name;
-- 等效如下
select * from test_b b left join test_a a on test_a.name = test_b.name;

全连接

MySQL并不支持 full join 操作,可以使用左连接 union all 右连接的方式来达到这个效果,条数为左连接条数 + 右连接条数 = 15

select * from test_a a left join test_b b on a.name = b.name
union all
select * from test_a a right join test_b b on a.name = b.name;

笛卡尔连接

又称交叉连接,一般情况下很少使用

-- A和B的笛卡尔集,即A的每一条都和B的每一条关联,所以条数为A * B,示例中是5 * 8 = 40
select count(*) from test_a a cross join test_b b;
-- 通过过滤条件达到内连接的效果
select * from test_a a cross join test_b b where a.name = b.name;

on and和on where的区别

在使用left join时,on and和on where条件的区别如下:  
1、on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。

(实际上左连接中如果有and语句是对左表进行过滤的,那么不管真假都不起任何作用。如果是对右表过滤的,那么左表所有记录都返回,右表筛选以后再与左表连接返回,即on and只能对右表过滤)  
2、where条件是在临时表生成好后,再对临时表进行过滤的条件(一般使用为对最左表的过滤)。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉,on后的条件用来生成左右表关联的临时表,where后的条件对临时表中的记录进行过滤。

-- 第一条语句比较好理解,筛选之后跟左表连接,第二条语句输出同第一条,说明on and即是对右表进行过滤,建议使用第二条这一种(易读)
select * from test_a a left join (select * from test_b where name = '香蕉') b on b.name = a.name order by a.id;
select * from test_a a left join test_b b on b.name = a.name and b.name = '香蕉' order by a.id;
-- 第一条语句比较好理解,筛选之后跟右表连接,第二条语句输出同第一条,说明on where一般对左表进行过滤,建议使用第二条这一种(易读)
select * from (select * from test_a where name = '香蕉') a left join test_b b on a.name = b.name;
select * from test_a a left join test_b b on a.name = b.name where a.name = '香蕉';

在使用inner join时,不管是对左表还是右表进行筛选,on and和on where都会对生成的临时表进行过滤。

JOIN从句的更多相关文章

  1. mysql学习之join从句

    一.join从句共有5种类型 内连接(inner join) 全外连接(full outer join) 左外连接(left outer join) 右外连接(right outer join) 交叉 ...

  2. hive中sql解析出对应表和字段的实现

    import java.io.IOException; import java.util.HashMap; import java.util.HashSet; import java.util.Map ...

  3. Hive 编程之DDL、DML、UDF、Select总结

    Hive的基本理论与安装可参看作者上一篇博文<Apache Hive 基本理论与安装指南>. 一.Hive命令行 所有的hive命令都可以通过hive命令行去执行,hive命令行中仍有许多 ...

  4. bootstrap教程,SQL

    版权声明:未经博主允许不得转载 SQL DDL数据定义语言 TPL事务处理语言 DCL数据控制语言 DML数据操作语言 DML SELECT INSERT UPDATE DELETE Join从句 J ...

  5. 查询SQL优化

    SQL优化的一般步骤 通过show status命令了解各种SQL的执行频率定位执行效率较低的SQL语句,重点select通过explain分析低效率的SQL确定问题并采取相应的优化措施 优化措施 s ...

  6. 慕课网--mysql开发技巧一 学习笔记

    现在存在下面的两张表,表的结构如下所示 师徒四人表结构:id,user_name,over数据:id user_name over1 唐僧 旃檀功德佛2 猪八戒 净坛使者3 孙悟空 斗战胜佛4 沙僧 ...

  7. 《Entity Framework 6 Recipes》中文翻译系列 (19) -----第三章 查询之使用位操作和多属性连接(join)

    翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-16  过滤中使用位操作 问题 你想在查询的过滤条件中使用位操作. 解决方案 假 ...

  8. 英语语法最终珍藏版笔记-17名词性-主语-宾语-同位语-表语-that从句

    名词性从句 在主从复合句中,从句可以充当主句的主语.表语.宾语或同位语.由于在多数情况下,主语.表语.宾语或同位语这四种句子成分由名词性词类充当,所以,我们把这些作用相当于名词的从句统称为名词性从句, ...

  9. hive regex insert join group cli

    1.insert Insert时,from子句既能够放在select子句后,也能够放在insert子句前,以下两句是等价的 hive> FROM invites a INSERT OVERWRI ...

随机推荐

  1. 关于构造IOCTL命令的学习心得

    在编写ioctl代码之前,需要选择对应不同命令的编号.为了防止对错误的设备使用正确的命令,命令号应该在系统范围内唯一,这种错误匹配并不是不会发生,程序可能发现自己正在试图对FIFO和audio等这类非 ...

  2. 通过网络仓库建立本地的yum仓库

    [root@kazihuo ~]# yum -y install createrepo yum-utils [root@kazihuo ~]# yum -y install https://mirro ...

  3. Linux下安装PHP的lua扩展库

    一.安装Lua 5.3.4 下载 http://www.lua.org/ftp/lua-.tar.gz tar xvf lua-.tar.gz cd lua- 重要:进入解压缩后的路径 cd .../ ...

  4. ArcGis10.1 Feature Class Properties无法编辑

    被这个问题困扰了很久,最后从官网帮助中查询到资料解决了 先看一下截图: 这种问题一般是FratureClass被锁,被mxd引用,并且发布服务有实例在运行,但我新创建一个FeatureClass也无法 ...

  5. angular4 get,post请求(带参数,与不带参数)

    一:在app.module.ts引入HttpMoudle import { BrowserModule } from '@angular/platform-browser'; import { Htt ...

  6. ubuntu 14.04安装JDK

    As a workaround, you can install OpenJDK 8 from a PPA repository: 1. Open terminal from the Dash or ...

  7. 20155303 2016-2017-2 《Java程序设计》第四周学习总结

    20155303 2016-2017-2 <Java程序设计>第四周学习总结 教材学习内容总结 第六章 继承与多态 6.1 何谓继承 继承避免多个类间重复定义共同行为,使用关键字exten ...

  8. POI读取Excel数据保存到数据库,并反馈给用户处理信息(导入带模板的数据)

    今天遇到这么一个需求,将课程信息以Excel的形式导入数据库,并且课程编号再数据库中不能重复,也就是我们需要先读取Excel提取信息之后保存到数据库,并将处理的信息反馈给用户.于是想到了POI读取文件 ...

  9. go 匿名函数和闭包

    匿名函数 1. 函数也是一种类型,因此可以定义作为一个函数类型的变量 package main import "fmt" // 函数作为参数 func add(a, b int) ...

  10. LINUX修改、增加IP的方法,一张网卡绑定多个IP/漂移IP【转】

    临时增加IP命令:ifconfig eth0:1 ip地址 netmask 子网码 broadcast 广播地址 gateway 网关  ifconfig eth0:1 10.1.104.65 net ...