欢迎来到徐庆高(Tea)的个人博客网站
磨难很爱我,一度将我连根拔起。从惊慌失措到心力交瘁,我孤身一人,但并不孤独无依。依赖那些依赖我的人,信任那些信任我的人,帮助那些给予我帮助的人。如果我愿意,可以分裂成无数面镜子,让他们看见我,就像看见自己。察言观色和模仿学习是我的领域。像每个深受创伤的人那样,最终,我学会了随遇而安。
当前位置: 日志文章 > 详细内容

SQL join中on和where的区别解析

2025年08月11日 MsSqlserver
0.结论两个表在,join时,首先做一个笛卡尔积,on后面的条件是对这个笛卡尔积做一个过滤形成一张临时表,如果没有where就直接返回结果,如果有where就对上一步的临时表再进行过滤。先on,再jo

0.结论

  • 两个表在,join时,首先做一个笛卡尔积,on后面的条件是对这个笛卡尔积做一个过滤形成一张临时表,如果没有where就直接返回结果,如果有where就对上一步的临时表再进行过滤。
    • 先on,再join,再where
    • 在使用left join时,on和where条件的区别如下:
  • 1、on条件是在生成临时表时使用的条件,它不管on中的条件是否为真,都会返回左边表中的记录。
  • 2、where条件是在临时表生成好后,再对临时表进行过滤的条件。这时已经没有left join的含义(必须返回左边表的记录)了,条件不为真的就全部过滤掉

1.数据准备

drop table if exists `class`;
create table `class`
(
    `c_id`   int          default null comment '班级id',
    `c_name` varchar(50) default null comment '班级名'
);
drop table if exists `student`;
create table `student`
(
    `s_id`   int          default null comment '学生id',
    `s_name` varchar(50) default null comment '学生名',
    `c_id`   int          default null comment '班级id'
);
insert into `class` (`c_id`, `c_name`)
values (1, '一班'),
       (2, '二班'),
       (3, '三班');
insert into `student` (`s_id`, `s_name`, `c_id`)
values (1, '张三', 1),
       (2, '李四', 2),
       (3, '王五', 4);

2.测试

-- 单表
select * from class c;
select * from student s;
-- 笛卡尔积
select * from class c inner join student s 										order by c.c_id, s.s_id;
-- 内连
select * from class c inner join student s on c.c_id = s.c_id order by c.c_id, s.s_id;
-- 左外连(先on,再join,再where)
select * from class c left  join student s on c.c_id = s.c_id 									order by c.c_id, s.s_id;
select * from class c left  join student s on c.c_id = s.c_id and   c.c_id <> 2	order by c.c_id, s.s_id;
select * from class c left  join student s on c.c_id = s.c_id where c.c_id <> 2	order by c.c_id, s.s_id;
select * from class c left  join student s on c.c_id = s.c_id and   s.c_id <> 2	order by c.c_id, s.s_id;
select * from class c left  join student s on c.c_id = s.c_id where s.c_id <> 2	order by c.c_id, s.s_id;

2.1.普通

2.1.1.class单表

2.1.2.student单表

2.1.3.笛卡尔积

2.1.4. 内连接

2.2.5.普通外连

2.2.重点来啦-外连接

2.2.1.一

2.2.2.二

2.2.3.三

2.2.4.四

3.参考资料

sql语句中left join的on和where有什么区别