SQL中使用JOIN时,过滤条件的位置
sql语句
(SELECT * FROM t1 WHERE {subquery_where_condition}) a JOIN (SELECT * FROM t2 WHERE {subquery_where_condition}) b ON {on_condition} WHERE {where_condition};
计算顺序
- 子查询中的where子句,即
- JOIN子句中的关联条件,即
- JOIN结果集中的where子句,即
过滤条件位置
- inner join
左右表的过滤条件不受限制 - left join
左表过滤条件放在{subquery_where_condition}或{where_condition}中,右表过滤条件放在{subquery_where_condition}或{on_condition}中 - right join
右表的过滤条件放在{subquery_where_condition}或{where_condition}中,左表过滤条件放在{subquery_where_condition}或 - full outer join
过滤条件只能放在{subquery_where_condition}中
推荐做法
将每个表的单表过滤条件单独写成子查询。
本文来自博客园,作者:jsqup,转载请注明原文链接:https://www.cnblogs.com/jsqup/p/16963186.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?