七种 JOIN 的 SQL 编写|学习笔记

简介: 快速学习七种 JOIN 的 SQL 编写

开发者学堂课程【MySQL 高级应用 - 索引和锁七种 JOIN 的 SQL 编写】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/598/detail/8590


七种 JOIN 的 SQL 编写

内容介绍:

一、建表 SQL

二、七种 JION 的编写

一、建表 SQL

首先建立两个表

CREATE TABLEtbl_dept(

idINT(11)NOTNULLAUTO_INCREMENT,

deptNameVARCHAR(30)DEFAULT NULL,locAddVARCHAR(40)DEFAULT NULL

PRIMARY KEY (id)

)ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

CREATE TABLEtbl_emp(

idINT(11) NOT NULL AUTO_INCREMENT,

nameVARCHAR(20) DEFAULT NULL,

deptldINT(11)DEFAULT NULL,

PRIMARY KEY (id),

KEYfk_dept_id(deptld')

#CONSTRAINTfk_dept_idFOREIGN KEY (deptld)REFERENCES tbl_dept(id )

)ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

INSERT INTO tbl_dept(deptName,locAdd) VALUES(RD,11);

INSERT INTO tbl_dept(deptName,locAdd) VALUES(HR,12);

INSERT INTO tbl_dept(deptName,locAdd)VALUES(MK,13);

INSERT INTO tbl_dept(deptName,locAdd) VALUES(MIS,14);

INSERT INTO tbl_dept(deptName,locAdd) VALUES(‘FD,15);

INSERT INTO tbl_emp(NAME,deptld) VALUES(z3,1);

INSERT INTO tbl_emp(NAME,deptld)VALUES(z4,1);

INSERT INTO tbl_emp(NAME,deptld)VALUES(z5,1);

INSERT INTO tbl_emp(NAME,deptld) VALUES(w5,2);

INSERT INTO tbl_emp(NAME,deptld) VALUES(‘w6,2);

INSERT INTO tbl_emp(NAME,deptld) VALUES('s7,3);

INSERT INTO tbl_emp(NAME,deptld)VALUES('s8',4);

INSERT INTO tbl_emp(NAME,deptld)VALUES('s9',51);

RD(研发部)这个部门在11楼,HR 这个部门在12楼,MK(市场部)在13层,MIS(后勤)在14楼,FD(财务部)在15

二、七种 SQL 的编写

1.内连接

SELECTFROM

TablcA A

LINNER JOIN TableB B

ON A.Key = B.Key

image.png

image.png

2.A

SELECT

FROM TableA A

LEFT JOIN TableB B

ON A.Key = B.Key

image.png

image.png

红色是两表的共有部分蓝色是 a 表的独有

3.B

SELECT

FROM TableA A

RIGHT JOIN TableBB

ON A.Key = B.Key

image.png

image.png

红色是公有部分蓝色是 b 表独有

4. A

SELECT selecn list>

FROM TableA A

LEFT JOIN TableB B

ON A.Key =B.Key

WHERE.BKey IS NULL.

image.png

image.png

a 要独那么 b 一定是 null

5.B

SELECT

FROM TablcA A

RIGHT JOIN TableB B

ON A.Key = B.Key

WHERE.A.Key IS NULL.

image.png

image.png

b 要独那么 a 要牺牲掉所以是 null

6.全连接

SELECT

FROMTableA A

FULEL OLSTER JOIN TableB B

ON A.Key = B.Key

image.png

image.png

上边是 ab 的共有下面蓝色和红色分别是 a 的独有和 b 的独有

合起来就是全有

7.AB 各自的独有

SELECT

FROM TableA A

FULLOUTER JOIN TableB B

ON A.Key = B.Key

WHEREA.Key IS NULL

OR B.Key IS NULL

image.png

image.png

蓝色是独 a 红色是独 b

相关文章
|
2月前
|
SQL
SQL JOIN
【11月更文挑战第06天】
49 4
|
3月前
|
SQL 关系型数据库 MySQL
图解 SQL 里的各种 JOIN
用文氏图表示 SQL 里的各种 JOIN,一下子就理解了。
52 2
|
3月前
|
SQL 分布式计算 Java
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
Hadoop-11-MapReduce JOIN 操作的Java实现 Driver Mapper Reducer具体实现逻辑 模拟SQL进行联表操作
55 3
|
5月前
|
Java 网络架构 数据格式
Struts 2 携手 RESTful:颠覆传统,重塑Web服务新纪元的史诗级组合!
【8月更文挑战第31天】《Struts 2 与 RESTful 设计:构建现代 Web 服务》介绍如何结合 Struts 2 框架与 RESTful 设计理念,构建高效、可扩展的 Web 服务。Struts 2 的 REST 插件提供简洁的 API 和约定,使开发者能快速创建符合 REST 规范的服务接口。通过在 `struts.xml` 中配置 `<rest>` 命名空间并使用注解如 `@Action`、`@GET` 等,可轻松定义服务路径及 HTTP 方法。
70 0
|
5月前
|
SQL 存储 数据挖掘
"SQL JOIN大揭秘:解锁多表联合查询的终极奥义,从内到外,左至右,全连接让你数据世界畅通无阻!"
【8月更文挑战第31天】在数据库领域,数据常分散在多个表中,而SQL JOIN操作如同桥梁,连接这些孤岛,使数据自由流动,编织成复杂的信息网络。本文通过对比内连接、左连接、右连接和全连接的不同类型,并结合示例代码,展示SQL JOIN的强大功能。掌握JOIN技术不仅能高效查询数据,更是数据分析和数据库管理的关键技能。
135 0
|
6月前
|
JSON 数据格式 SQL
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
SQL开发问题之直接使用join方法在处理字符串类型属性时可能会遇到性能问题如何解决
|
6月前
|
SQL
SQL FULL OUTER JOIN 关键字
【7月更文挑战第17天】SQL FULL OUTER JOIN 关键字。
49 6
|
6月前
|
SQL 算法 数据库
SQL优化器原理 - Join重排
保证等价性:不同的Join顺序可能产生相同的结果集,但执行成本可能不同。因此,在重排Join顺序时,必须确保结果集的等价性。
|
6月前
|
SQL 算法 数据库
SQL优化器原理 - Join重排。
保证等价性:不同的Join顺序可能产生相同的结果集,但执行成本可能不同。因此,在重排Join顺序时,必须确保结果集的等价性。
|
6月前
|
监控 前端开发 SQL
ODPS SQL问题之在何种情况下建议使用Distributed Map Join
ODPS SQL问题之在何种情况下建议使用Distributed Map Join