Mysql进阶(内、外、自然连接)

mysql进阶篇

本人也是很久之前学习了mysql,今天打算复习一下随手写一篇笔记整理一下

1.连接(连结)查询

按照我们设计表的一个规范,一个实体应该在一张表里面完成
如果一个业务要使用多个实体的数据呢?那是不是应该有多张表一起使用,将多个表的记录连结起来,这就是连接的目的

在这里插入图片描述
上图这张表描述了哪一个老师在什么时期之内教了哪个班级
我们现在用一个表来存储它是可以做到的,但是按照数据库的设计规范的话,它是不符合第三范式的,他有传递依赖
所以我们要将这个表拆为三部分,从而做一些查询
在这里插入图片描述

create table join_teacher(
id int primary key auto_increment,
t_name varchar(20),
gender enum('male','famale')
) engine innoDB character set utf8;

insert into join_teacher values
(1,'冯老师','male'),
(2,'魏老师','famale'),
(3,'秦老师','male'),
(4,'陈老师','male');

create table join_class(
id int primary key auto_increment,
c_name char(10),
room char(5)
) engine innoDB character set utf8;

insert into join_class values
(1,'python1','33201'),
(2,'python2','33202'),
(3,'python3','33203'),
(4,'python4','33204');

create table join_teacher_class(
id int primary key auto_increment,
t_id int,
c_id int,
days int,
start_date date,
end_date date
) engine innoDB character set utf8;

insert into join_teacher_class values
(1,1,1,15,"2019-03-05","2019-03-20"),
(2,1,1,5,"2019-03-05","2019-03-10"),
(3,2,2,20,"2019-03-05","2019-03-25"),
(4,2,2,1,"2019-03-05","2019-03-06"),
(5,3,3,7,"2019-03-05","2019-03-12"),
(6,1,1,8,"2019-03-05","2019-03-13"),
(7,3,3,4,"2019-03-05","2019-03-09");

连接总体思路:将数据按照某种条件连接起来在做查询,因为连接的条件不同,连接又分为:内连接,外连接,自然连接,连接是指根据表规定的结构来进行数据的连接,首先讲解什么是内连接

内连接

数据内部的连接,要求连接的多个数据必须真实存在才能进行连接
先来段语法,一看便知一二
table_left inner join table_right on(连接条件) ps:在join左边则是左表,右边则为右表
来个例子:
我们查询一下每个老师带了多少天课
在这里插入图片描述

select join_teacher.t_name,join_teacher_class.days from join_teacher inner join join_teacher_class on join_teacher.id=join_teacher_class.t_id;

先不要看这个语法,先看一下这个结果有没有展示陈老师的代课信息
在这里插入图片描述
因为当前没有记录可以和陈老师进行连接,内连接不存在连接不上的数据
在这里插入图片描述
我们先分析一下这个连接过程:
首先将所有的数据连接起来(图中第一步)
在这里插入图片描述
PS:不满足条件结果不保留

内连接在连接时是可以省略条件的,一旦省略条件mysql这判断所有连接全为真,意味着所有左表数据都要与右表的记录做一次连接,共有 m*n个连接
这种没有条件的内连接叫做交叉连接或笛卡尔积,笛卡尔积是获得最高记录数的一种,当然处理起来也是非常缓慢的,除非是将所有可能性展示出来,否则不做这种笛卡尔积连接的
Mysql中 inner join是默认的连接方式 所以inner是可以省略的

外连接

如果负责连接的多个数据不真实存在,称之为外连接
外连接分类:左外连接、右外连接、全外连接 但是mysql没有全外连接
左外连接:在连接时如果出现左边表数据连接不到右边表的情况.则左边表的数据在最终结果里保留,如果右表数据连接不到左表,则右表数据被丢弃(灵魂画师别介意
右外连接反之
在这里插入图片描述

跟内连接的例子一样 : 我们查询一下每个老师带了多少天课

在这里插入图片描述

select join_teacher.t_name,join_teacher_class.days from join_teacher left outer join join_teacher_class on join_teacher.id=join_teacher_class.t_id;

left outer join (outer是可以省略的)
而这里出现了陈老师的信息
在这里插入图片描述
当数据连接不上时 保留左表 右边用虚拟数据代替
左连接是开发过程中用到最多的一种连接方式
注意:外连接不能使用where

自然连接

natural join 通过mysql自己的判断完成连接
自然连接暂不介绍,有时间我会补上

注意

取别名:
select join_teacher.t_name,join_teacher_class.days from join_teacher left outer join join_teacher_class on join_teacher.id=join_teacher_class.t_id;
将表名称取别名后:
select t.t_name,tc.days from join_teacher as t left outer join join_teacher_class as tc on t.id=tc.t_id;
跟上面语句一样 变得更简洁更清晰

无论是连接条件还是连接查询多字段列表,没有必要一定要写 表名.字段的写法,是否写,取决于是否发生了冲突,冲突需要些,不冲突无所谓,建议写上,提高代码的可读性

以上就是本章的全部内容了,因为时间关系写的有些匆忙,后期会做一些修改,光看是学不会的,重要的是练习,最后感谢大家的阅读

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值