MySQL内外连接
- 表的连接分为内连接和外连接
内连接
- 内连接实际上就是利用where子句对两种表形成的笛卡尔积进行筛选,也是开发中使用最多的连接查询
语法:
sql
select 字段 from 表1 inner join 表2 on 连接条件 and 其他条件;
就是使用inner join table_2 on someting代替了原来的条件
外连接
- 外连接分为左外连接和右外连接
左外连接
- 使用左外连接,就是说左边的内容会被完全显示,但是右边的如果有匹配的就显示,如果没有匹配的就显示为NULL
语法:
sql
select 字段名 from 表名1 left join 表名2 on 连接条件
eg:
sql
-- 建两张表
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);
-- 查询所有学生的成绩,如果这个学生没有成绩,也要将学生的个人信息显示出来
-- 当左边表和右边表没有匹配时,也会显示左边表的数据
select * from stu left join exam on stu.id=exam.id;
右外连接
sql
select 字段 from 表名1 right join 表名2 on 连接条件;
eg:
sql
-- 对stu表和exam表联合查询,把所有的成绩都显示出来,即使这个成绩没有学生与它对应,也要显示出来
select * from stu right join exam on stu.id=exam.id;
其实右连接也可以使用左连接来实现,就是要换一下两个表的位置即可