目录
[2.1 左外连接](#2.1 左外连接)
[2.2 右外连接](#2.2 右外连接)
在观看本章之前,请确保有复合查询的基础,若没有,建议移转到MySQL复合查询
1.内连接
内连接实际上就是利用 where 子句对两种表形成的笛卡儿积进行筛选,在复合查询都是内连接,也是在开发过程中使用的最多的连接查询。
语法:
cpp
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;
eg:显示SMITH的名字和部门名称
前置工作:
创建一个雇员信息表(来自 oracle 9i 的经典测试表)
EMP 员工表
DEPT 部门表
SALGRADE 工资等级表
复合查询的写法:
cpp
mysql> select ename,dname from emp,dept where emp.deptno=dept.deptno
and ename='SMITH';
+-------+----------+
| ename | dname |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
内连接的写法
cpp
mysql> select ename,dname from emp inner join dept on emp.deptno=dept.deptno
and ename='SMITH';
+-------+----------+
| ename | dname |
+-------+----------+
| SMITH | RESEARCH |
+-------+----------+
2.外连接
外连接分为左外连接和右外连接
2.1 左外连接
如果联合查询,左侧的表完全显示我们就说是左外连接。
语法:
cpp
select 字段名 from 表名1 left join 表名2 on 连接条件
eg:查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来
cpp
-- 建两张表
create table stu (id int, name varchar(30)); -- 学生表
insert into stu values(1,'jack'),(2,'tom'),(3,'kity'),(4,'nono');
create table exam (id int, grade int); -- 成绩表
insert into exam values(1, 56),(2,76),(11, 8);
cpp
-- 当左边表和右边表没有匹配时,也会显示左边表的数据
mysql> select * from stu left join exam on stu.id=exam.id;
+------+------+------+-------+
| id | name | id | grade |
+------+------+------+-------+
| 1 | jack | 1 | 56 |
| 2 | tom | 2 | 76 |
| 3 | kity | NULL | NULL |
| 4 | nono | NULL | NULL |
+------+------+------+-------+
2.2 右外连接
如果联合查询,右侧的表完全显示我们就说是右外连接。(其实把左右表的顺序一换,就可以使用左外连接)
语法:
cpp
select 字段 from 表名1 right join 表名2 on 连接条件;
这里和左外连接差不多,大家可以自行尝试