Mysql多表查询 思路 ——示例——sql顺序

参考练习题:https://blog.csdn.net/weixin_49627122/article/details/126380916

SQL顺序

在 SQL 查询中,SELECT 语句的执行顺序不是按照查询语句的书写顺序执行的,而是按照逻辑执行阶段来进行。一般来说,SQL 查询的执行顺序可以分为以下几个步骤:

  1. FROM: 指定要查询的表,执行这一步时会生成一个虚拟的结果集,包含了所有所需的列和行。

  2. JOIN: 如果查询涉及到多个表,会执行连接操作(JOIN)来合并不同表中的数据。

  3. WHERE: 对每一行应用 WHERE 子句中的条件,筛选出满足条件的行。

  4. GROUP BY: 根据 GROUP BY 子句中的列进行分组。

  5. HAVING: 对每个分组应用 HAVING 子句中的条件,筛选出满足条件的分组。

  6. SELECT: 选择要在结果集中显示的列,应用聚合函数(如果有的话)。

  7. ORDER BY: 对结果集进行排序。

  8. LIMIT/OFFSET: 如果使用了 LIMITOFFSET,最后会应用这些限制。

虽然这是一个一般性的执行顺序,但实际的数据库系统可能会根据查询的具体情况进行一些优化,以提高性能。在复杂的查询中,数据库系统可能会重新安排执行计划,例如使用索引来加速搜索,以获得更高的执行效率。

需要注意的是,虽然 SQL 查询的逻辑执行顺序如上所述,但在实际执行中,数据库引擎可能会根据优化器的决策进行重新排列操作,以提高性能。

思路

多表最重要的还是要理清楚逻辑,根据slq运行顺序,将需求一步步的分为多个sql,根据规则拼凑而成。

字段可以作为,表查询结果的字段, 表也可以作为,查询结果的表

代码示例

查询结果为字段情况

sql 复制代码
# 查询结果为字段情况
SELECT st.id,
       st.name,
       (
           SELECT sc.s_id
           FROM scores sc
                    INNER JOIN course co ON sc.c_id = co.id
           WHERE co.id = 1
             AND sc.score > 60
             AND st.id = sc.s_id
           LIMIT 1 -- 限制只返回一个值
       ) AS scco
FROM student st
WHERE (
          SELECT sc.s_id
          FROM scores sc
                   INNER JOIN course co ON sc.c_id = co.id
          WHERE co.id = 1
            AND sc.score > 60
            AND st.id = sc.s_id
          LIMIT 1 -- 限制只返回一个值
      ) IS NOT NULL;

查询结果为表的情况

sql 复制代码
# 查询结果为表的情况
select st.id, st.name, scco.score
from student st
         inner join (select sc.score, sc.s_id
                     from scores sc
                              inner join course co on sc.c_id = co.id
                     where co.id = 1
                       and sc.score > 60) as scco on scco.s_id = st.id;

查询结果为子查询情况

sql 复制代码
#查询结果为 子查询条件的情况
select st.id, st.name
from student st
where st.id in (select sc.s_id
                from scores sc
                         left join course co on sc.c_id = co.id
                where co.id = 1
                  and sc.score > 60);
相关推荐
岁岁种桃花儿2 分钟前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
jiunian_cn1 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐1 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
Exquisite.2 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
知识分享小能手3 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
踩坑小念4 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶4 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok5 小时前
MySQL的常用数据类型
数据库·mysql
曹牧5 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle
J_liaty5 小时前
Redis 超详细入门教程:从零基础到实战精通
数据库·redis·缓存