MySql速成笔记6(DQL多表)

想汇总结果的时候可以用垂直合并

注意:主键名 inner join 外键名 还是 外键名 inner join 主键名 效果一样

注意外连接是必须要加 主外键相等的(on)

  • 连续 LEFT JOIN 中,每次的逻辑主表是上一次 JOIN 的中间结果集(保证主表记录不丢失)。
  • 但中间结果集包含了所有已关联原始表的字段,因此原始表的别名在后续所有 JOIN 中仍可引用(全局有效)也就是说用原始表的别名访问的是中间结果集的数据。
sql 复制代码
SELECT *
FROM users AS u
LEFT JOIN orders AS o ON u.user_id = o.user_id
LEFT JOIN order_details AS od ON u.user_id = od.user_id;  -- 直接用 u.user_id 关联(假设详情表也有 user_id)
  1. SELECT 子句与 ON 子句的关系

    • ON 子句用于定义表之间的关联条件,决定多表如何合并(哪些记录会被匹配关联)。
    • SELECT 子句用于从合并后的完整结果集中筛选需要返回的字段 ,它不影响表的关联逻辑,只影响最终输出的列。因此,SELECT 后指定的字段与 ON 中的关联条件确实没有直接关系(前者是 "选列",后者是 "关联规则")。
  2. MySQL 处理多表连接时的数据可见性 :执行多表连接时,MySQL 会先根据所有 JOINON 条件构建一个包含所有关联表字段的中间结果集 (可以理解为 "临时合并表"),这个结果集包含了符合关联条件的所有记录及相关字段(即使某些字段在 SELECT 中没被选中,它们在中间过程中也是存在的)。最终,SELECT 子句从这个中间结果集中 "挑选" 需要的字段返回给用户,相当于对中间结果集做了一次 "列过滤"。

    SELECT u.user_id -- 只返回用户ID
    FROM users AS u
    LEFT JOIN orders AS o ON u.user_id = o.user_id -- 关联用户和订单
    LEFT JOIN order_details AS od ON u.user_id = od.user_id; -- 关联用户和订单详情

  • 中间结果集会包含 usersordersorder_details 三表的所有字段(如 u.user_ido.order_idod.detail_id 等)。
  • SELECT u.user_id 仅决定最终结果只显示 u.user_id 这一列,但不影响三表的关联逻辑(ON 条件依然会正常执行,确保关联正确)。
相关推荐
William Dawson1 天前
2026软考中级系统集成项目管理工程师备考笔记
笔记·系统集成项目管理工程师
love530love1 天前
精简版|Claude-HUD 插件介绍 + 一键安装教程
人工智能·windows·笔记
想成为优秀工程师的爸爸1 天前
第三十篇技术笔记:郭大侠学UDS - 人有生老三千疾,望闻问切良方医
网络·笔记·网络协议·tcp/ip·信息与通信
tq10861 天前
数学:约束表征空间的最小闭包
笔记
freexyn1 天前
Matlab自学笔记七十六:表达式的展开、因式分解、化简、合并同类项
笔记·算法·matlab
IT摆渡者1 天前
linux 系统安全检查
运维·网络·经验分享·笔记
十安_数学好题速析1 天前
【多选】曲线方程:四步避坑判断曲线类型
笔记·学习·高考
chase。1 天前
【学习笔记】skrl: 模块化、灵活的强化学习库深度解析
笔记·学习
其实防守也摸鱼1 天前
CSDN博客写什么?从0到1打造你的技术影响力
笔记·测试用例·博客·教程·ai写作·ai辅助·高质量
EQ-雪梨蛋花汤1 天前
【Unity笔记】Unity 音游模板与免费资源:高效构建节奏游戏开发全指南
笔记·unity·游戏引擎