当前位置: 首页 > news >正文

SQL 多表查询常用语法速查:INNER JOIN / LEFT JOIN / RIGHT JOIN

在实际开发和面试中,SQL 的多表查询是最常见的场景之一。比如:

用户信息存放在 users 表;

订单信息存放在 orders 表;

如果想要查询用户的订单,就必须把这两张表的数据结合起来。

SQL 提供了 JOIN 语法 来完成多表查询,其中最常用的是:

INNER JOIN(内连接)

LEFT JOIN(左连接)

RIGHT JOIN(右连接)

本文将用简洁的语法示例帮你快速掌握这些 JOIN 的区别与用法。

一、INNER JOIN(内连接)

语法

SELECT u.id, u.name, o.order_id, o.amount

FROM users u

INNER JOIN orders o ON u.id = o.user_id;

特点

只返回两张表中 匹配成功 的数据。

如果某个用户没有订单,他不会出现在结果里。

适用场景

只关心两张表都有交集的数据,例如:查询“有下过单的用户”。

二、LEFT JOIN(左连接)

语法

SELECT u.id, u.name, o.order_id, o.amount

FROM users u

LEFT JOIN orders o ON u.id = o.user_id;

特点

返回左表的全部数据。

如果右表没有匹配,则结果中的右表字段为 NULL。

适用场景

需要保留左表的完整数据,例如:查询“所有用户及其订单情况”,即使有用户没有下过单,也要展示。

三、RIGHT JOIN(右连接)

语法

SELECT u.id, u.name, o.order_id, o.amount

FROM users u

RIGHT JOIN orders o ON u.id = o.user_id;

特点

和 LEFT JOIN 相反,返回右表的全部数据。

如果左表没有匹配,则结果中的左表字段为 NULL。

适用场景

需要保留右表的完整数据,例如:查询“所有订单对应的用户”,即使有订单没有匹配到用户(脏数据),也要展示。

四、JOIN 的总结对比

● INNER JOIN:只要匹配成功的数据,交集。

● LEFT JOIN:保留左表全部,右表能匹配则显示,不能则 NULL。

● RIGHT JOIN:保留右表全部,左表能匹配则显示,不能则 NULL。

面试时常问:INNER JOIN 和 LEFT JOIN 的区别?

答:INNER JOIN 过滤掉不匹配的数据,而 LEFT JOIN 会保留左表全部行。

五、面试高频考点

1. INNER JOIN 和 WHERE 的区别?

INNER JOIN 在连接阶段就决定匹配,WHERE 是对结果进一步过滤。

写错位置可能导致结果数量不同。

2. LEFT JOIN 为什么容易写出逻辑错误?

如果把条件写在 WHERE,而不是 ON,会把没有匹配的数据也过滤掉,相当于变成 INNER JOIN。

正确做法:过滤条件写在 ON 上,WHERE 用于最终筛选。

3. 什么时候用 RIGHT JOIN?

实际开发中较少用,一般用 LEFT JOIN 调整表顺序即可。

但面试里可能会考概念。

六、总结

● INNER JOIN:最常用,取交集。

● LEFT JOIN:保留左表,常用于“全量用户 + 订单情况”。

● RIGHT JOIN:保留右表,实际开发少用。

面试常考 ON 和 WHERE 的区别,千万不要混淆。

👉 建议:多写实际 SQL,配合 EXPLAIN 分析执行计划,才能理解 JOIN 的本质。

http://www.dtcms.com/a/430902.html

相关文章:

  • p2p网贷网站开发页面设计简单吗
  • Java SE “异常处理 + IO + 序列化”面试清单(含超通俗生活案例与深度理解)
  • Redis 数据库管理与通信基础
  • GameObject 常见类型详解 -- 运输工具(TRANSPORT)
  • Spring的事务管理机制
  • DAY22 XML、XML解析
  • Lazygi - 让git操作不再困难
  • sns社交网站建设东莞服务36招
  • 有那些方法推广网站可用的在线网页代理
  • 一种基于模型残差的密度聚类方法之二(电力线分股)
  • 基于Keil下多文件打包生成LIB库的具体步骤
  • php网站开发教学购物软件哪个更好更便宜
  • 中小企业网站开发长期做网站应该购买稳定的空间
  • 二叉树的递归层序遍历
  • 牛客算法基础noob58 无限长正整数排列字符串
  • ECharts 配置语法详解
  • 哪个网站做自媒体比较好华为网站建设的目标是否明确
  • 【机器学习】 在Jupyter Notebook 中如何指定Python环境
  • springboot海洋馆预约系统的设计与实现(代码+数据库+LW)
  • 精通C语言(1.内存函数)
  • Radio Garden官网入口 - 全球广播电台在线收听网站|网页版|打不开
  • 基于以太坊的Dao治理系统
  • 【LeetCode_203】移除链表元素
  • LeetCode刷题记录----75.颜色分类
  • QQ可以在网站做临时会话么温州的网站建设公司
  • Java-Spring 入门指南(十七)SpringMVC--Apipostl与RestFul实战测试
  • Codeforces Round 993A Easy Problem
  • OSI模型、网络地址、与协议
  • Codeforces Round 993B. Normal Problem
  • 《嵌入式 – GD32开发实战指南(RISC-V版本)》第3章 GPIO流水灯的前世今生