开发者学堂课程【MySQL 高级应用 - 索引和锁:七种 JOIN 的 SQL 编写】学习笔记,与课程紧密联系,让用户快速学习知识。
课程地址:https://developer.aliyun.com/learning/course/598/detail/8590
七种 JOIN 的 SQL 编写
内容介绍:
一、建表 SQL
二、七种 JION 的编写
一、建表 SQL
首先建立两个表
CREATE TABLE
’tbl_dept’(
‘id’INT(11)NOTNULLAUTO_INCREMENT,
‘deptName’VARCHAR(30)DEFAULT NULL,’locAdd’VARCHAR(40)DEFAULT NULL
PRIMARY KEY (id
’)
)ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;
CREATE TABLE
’tbl_emp’(
‘id’INT(11) NOT NULL AUTO_INCREMENT,
‘name’VARCHAR(20) DEFAULT NULL,
‘deptld’INT(11)DEFAULT NULL,
PRIMARY KEY (
‘id’),
KEY
’fk_dept_id’(‘deptld')
#CONSTRAINT
‘fk_dept_id’FOREIGN 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
2.全 A
SELECT
FROM TableA A
LEFT JOIN TableB B
ON A.Key = B.Key
红色是两表的共有部分蓝色是 a 表的独有
3.全 B
SELECT
FROM TableA A
RIGHT JOIN TableBB
ON A.Key = B.Key
红色是公有部分蓝色是 b 表独有
4. 独 A
SELECT selecn list>
FROM TableA A
LEFT JOIN TableB B
ON A.Key =B.Key
WHERE.BKey IS NULL.
a 要独那么 b 一定是 null
5.独 B
SELECT
FROM TablcA A
RIGHT JOIN TableB B
ON A.Key = B.Key
WHERE.A.Key IS NULL.
b 要独那么 a 要牺牲掉所以是 null
6.全连接
SELECT
FROMTableA A
FULEL OLSTER JOIN TableB B
ON A.Key = B.Key
上边是 a、b 的共有下面蓝色和红色分别是 a 的独有和 b 的独有
合起来就是全有
7.A、B 各自的独有
SELECT
FROM TableA A
FULLOUTER JOIN TableB B
ON A.Key = B.Key
WHEREA.Key IS NULL
OR B.Key IS NULL
蓝色是独 a 红色是独 b