4、外连接
按照某一张表作为主表(表中所有记录在最后都会保留)根据条件取连接另外一张表,从而得到目标数据
外连接分为两种
- 左连接:左表是主表
- 右连接:右表是主表
4.1、原理
- 确定主表,左连接就是左边的表为主表,右连接就是右边的表为主表
- 拿主表的每一条记录,去匹配另外的一张表(从表)的每一条记录
- 如果满足匹配条件,保留,不满足即不保留
- 如果主表记录在从表中一条都没有匹配成功,那么也要保留记录, 从表对应的字段值都是null
4.2、基本语法
-- 左连接 主表 left join 从表 on 连接条件; -- 右连接 从表 right join 主表 on 连接条件;
左表的数据在前,右表的数据在后
mysql> select * from my_student; +----+--------+----------+------+--------+ | id | name | class_id | age | gender | +----+--------+----------+------+--------+ | 1 | 刘备 | 1 | 18 | 2 | | 2 | 李四 | 1 | 19 | 1 | | 3 | 王五 | 2 | 20 | 2 | | 4 | 张飞 | 2 | 21 | 1 | | 5 | 关羽 | 1 | 22 | 2 | | 6 | 曹操 | 1 | 20 | NULL | +----+--------+----------+------+--------+ mysql> select * from my_class; +----+--------+ | id | name | +----+--------+ | 1 | 一班 | | 3 | 三班 | | 2 | 二班 | +----+--------+ mysql> select * from my_student as s left join my_class c on s.class_id = c.id; +----+--------+----------+------+--------+------+--------+ | id | name | class_id | age | gender | id | name | +----+--------+----------+------+--------+------+--------+ | 1 | 刘备 | 1 | 18 | 2 | 1 | 一班 | | 2 | 李四 | 1 | 19 | 1 | 1 | 一班 | | 3 | 王五 | 2 | 20 | 2 | 2 | 二班 | | 4 | 张飞 | 2 | 21 | 1 | 2 | 二班 | | 5 | 关羽 | 1 | 22 | 2 | 1 | 一班 | | 6 | 曹操 | 1 | 20 | NULL | 1 | 一班 | +----+--------+----------+------+--------+------+--------+ select * from my_student as s right join my_class c on s.class_id = c.id; mysql> select * from my_student as s right join my_class c on s.class_id = c.id; +------+--------+----------+------+--------+----+--------+ | id | name | class_id | age | gender | id | name | +------+--------+----------+------+--------+----+--------+ | 1 | 刘备 | 1 | 18 | 2 | 1 | 一班 | | 2 | 李四 | 1 | 19 | 1 | 1 | 一班 | | 3 | 王五 | 2 | 20 | 2 | 2 | 二班 | | 4 | 张飞 | 2 | 21 | 1 | 2 | 二班 | | 5 | 关羽 | 1 | 22 | 2 | 1 | 一班 | | 6 | 曹操 | 1 | 20 | NULL | 1 | 一班 | | NULL | NULL | NULL | NULL | NULL | 3 | 三班 | +------+--------+----------+------+--------+----+--------+
4.3、特点
外连接中主表的数据一定会保存,连接之后不会出现记录数少于主表(内连接可能少数据)
左连接和右连接可以相互转换,但是数据对应的位置(字段顺序)会改变
4.4、应用
获取对应主表以及其他数据(关联)
通常使用左连接
5、using关键字
在连接查询中用来代替对应on关键字进行条件匹配
5.1、原理
- 在连接查询时,使用on的地方用using代替
- 使用using的前提是对应的两张表连接的字段名是同名的(类似自然连接)
- 如果使用using关键字,那么对应的同名字段,最后在结果中只会保留一个
5.2、基本语法
表1 [inner, left, right] join 表2 using (同名字段列表);
1
select * from my_student left join my_class using(class_id);
-- 等价于
select * from my_student left join my_class on my_student.class_id = my_class.class_id;
通常不使用