先放一张图, 比较直观
这里重点记录一下 left right inner 三种 join 的使用
首先创建两张表 kemu source , 用于演示
CREATE TABLE `test`.`kemu` (
`id` INT NOT NULL AUTO_INCREMENT,
`kemu` VARCHAR(255) NOT NULL,
PRIMARY KEY (`id`)
);
CREATE TABLE `test`.`source` (
`id` INT NOT NULL AUTO_INCREMENT,
`source` INT NOT NULL,
PRIMARY KEY (`id`)
);
然后插入一些数据
1. left join
顾名思义,就是“左连接”,表1左连接表2,以左为主,表示以表1为主,关联上表2的数据,查出来的结果显示左边的所有数据,然后右边显示的是和左边有交集部分的数据。如下:
SELECT
*
FROM
kemu
LEFT JOIN score ON kemu.id = score.kemu_id
2. right join
“右连接”,表1右连接表2,以右为主,表示以表2为主,关联查询表1的数据,查出表2所有数据以及表1和表2有交集的数据,如下
select
*
from
kemu
right join score on kemu.id = score.kemu_id
3. inner join
join,其实就是“inner join”,为了简写才写成join,两个是表示一个的,内连接,表示以两个表的交集为主,查出来是两个表有交集的部分,其余没有关联就不额外显示出来,这个用的情况也是挺多的,如下
select
*
from
kemu
join score on kemu.id = score.kemu_id