SQL中join操作后面的on 和 where 的区别
join关键字的作用是将多个表按一定的条件联合起来,从而可以实现从多个表中获取数据。
join的常见用法有join、left join 、right join 、full join。
on 和 where 的区别:
on 表示在 join 前进行条件筛选,然后再进行join操作。
where 表示在join操作完了再做过滤。
示例:
现在有两张表t1 和 t2,表里面的数据如下:
> select * from t1;
+------+------+
| id | age |
+------+------+
| 1 | 20 |
| 2 | 21 |
| 3 | 22 |
| 4 | 23 |
| 5 | 24 |
+------+------+
> select * from t2;
+------+------+
| id | name |
+------+------+
| 1 | Lee |
| 2 | Bob |
| 3 | Kate |
| 4 | Tony |
+------+------+
思考一下下面的sql 执行后的结果,有几条数据:
1)select * from t1 left join t2 on t1.id=t2.id and t1.id=1;
2)select * from t1 left join t2 on t1.id=t2.id and t2.id=1;
3)select * from t1 left join t2 on t1.id=t2.id where t1.id=1;
4)select * from t1 left join t2 on t1.id=t2.id where t2.id=1;
思考5秒钟......
1 seconds...
2 seconds...
3 seconds...
4 seconds...
5 seconds...
答案是:5、5、1、1
实际输出结果如下:
1) select * from t1 left join t2 on t1.id=t2.id and t1.id=1;
+------+------+------+------+
| id | age | id | name |
+------+------+------+------+
| 1 | 20 | 1 | Lee |
| 2 | 21 | NULL | NULL |
| 3 | 22 | NULL | NULL |
| 4 | 23 | NULL | NULL |
| 5 | 24 | NULL | NULL |
+------+------+------+------+
2) select * from t1 left join t2 on t1.id=t2.id and t2.id=1;
+------+------+------+------+
| id | age | id | name |
+------+------+------+------+
| 1 | 20 | 1 | Lee |
| 2 | 21 | NULL | NULL |
| 3 | 22 | NULL | NULL |
| 4 | 23 | NULL | NULL |
| 5 | 24 | NULL | NULL |
+------+------+------+------+
3) select * from t1 left join t2 on t1.id=t2.id where t1.id=1;
+------+------+------+------+
| id | age | id | name |
+------+------+------+------+
| 1 | 20 | 1 | Lee |
+------+------+------+------+
4) select * from t1 left join t2 on t1.id=t2.id where t2.id=1;
+------+------+------+------+
| id | age | id | name |
+------+------+------+------+
| 1 | 20 | 1 | Lee |
+------+------+------+------+
注意一点:
left join 时,左表的数据是完整的,on 条件会筛选需要关联的列,无论能否关联上,左表都是完整的。比如下面的例子:
> select * from t1 left join t2 on t1.id=t2.id and t2.id=10;
+------+------+------+------+
| id | age | id | name |
+------+------+------+------+
| 1 | 20 | NULL | NULL |
| 2 | 21 | NULL | NULL |
| 3 | 22 | NULL | NULL |
| 4 | 23 | NULL | NULL |
| 5 | 24 | NULL | NULL |
+------+------+------+------+
同理,right join 也是一样的。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· DeepSeek智能编程
· 精选4款基于.NET开源、功能强大的通讯调试工具
· [翻译] 为什么 Tracebit 用 C# 开发
· 腾讯ima接入deepseek-r1,借用别人脑子用用成真了~
· DeepSeek崛起:程序员“饭碗”被抢,还是职业进化新起点?