sql专题 之 sql的执行顺序

文章目录

  • sql的执行顺序
    • sql语句的格式
    • 实际的执行顺序:
    • 虚拟表 vs 数据集
      • 虚拟表
    • 结果集
    • 总结
    • 嵌套查询在sql查询中的执行顺序

前文我们了解了sql常用的语句,这次我们对于这些语句来个小思索
戳这里→ sql专题 之 常用命令

sql的执行顺序

SQL语句的执行顺序是数据库查询优化和结果生成的关键

sql语句的格式

	select distinct 要查的字段,sum(列字段),开窗函数from  左表l [left|inner] join  右表r on 连接条件where 筛选条件1 and 筛选条件2group by 分组的字段having 组的条件order by 排序的字段limit 限制数量;

实际的执行顺序:

from  左表l ② [left|inner] join  右表r on 连接条件⑧ selectdistinct 要查的字段,sum(列字段),⑦ 开窗函数③ where 筛选条件1 and 筛选条件2group by 分组的字段⑥ having 组的条件⑩ order by 排序的字段⑪ limit 限制数量;
  • 1、from

    识别查询的数据源,即确定要查询的表。
    如果from子句中包含多个表,那么就会进行第二步

  • 2、join on

    对from句中的表进行连接操作。可以是内连接(inner join)、左连接(left join)、右连接(right join)。连接的结果会生成一个新的包含所需数据的虚拟表

  • 3、where … and

    对虚拟表中的记录进行进一步的筛选,以排除不符合条件的记录。筛选后的结果又会生成一个新的虚拟表

  • 4、group by

    对虚拟表中的数据按照一个或者多个行进行分组,分组后仍会生成一个新的虚拟表

  • 5、聚合函数:avg、sum、count等

    使用聚合函数对每个组进行计算,并得出每个组的统计信息,然后将计算结果添加到group by的虚拟表中

  • 6、having

    对分组之后的结果进行进一步的筛选,筛选后的结果会生成一个新的虚拟表

  • 7、开窗函数

    对分组后的结果进行窗口函数计算,并生成一个新的结果集

  • 8、select [distinct]

    在having生成的虚拟表中选出符合条件的列,并生成一个新的结果集。
    如果使用了别名,也会进行替换。

  • 9、distinct

    去除结果集中的重复行。
    去重后的结果也会生成一个新的结果集。

  • 10、order by

    对结果集中的数据进行排序。
    排序后的结果会生成一个游标(注意,不是表了。因为排序会改变数据的物理顺序)

  • 11、limit/offset:返回限定的数量

    返回限制的数据数量,或者返回指定从哪条记录开始返回。

虚拟表 vs 数据集

虚拟表

通常指一种不实际存储数据的表结构,可是是视图、派生表或临时表。基于其他表或者查询的结果动态生成

  • 视图:
    create view my_view as select * from  student where class_id is not null
    

    这里的my_view是一个视图,它是基于student表中class_id不为空的条件生成的一个虚拟表。
    视图的虚拟表结构可以被定义并存储在数据库中,供后续查询使用

  • 派生表
    select * from  student where class_id is not nullas s1
    

    s1为派生表,是基于student表中class_id不为空的条件动态生成的

  • 虚拟表的特点:
    • 虚拟表是基于其他表或查询的结果动态生成的,本身不存储数据
    • 数据库管理系统可以对虚拟表进行查询优化,因为它们通常是基于特定查询需求动态生成的。
    • 可以被定义并存储在数据库中,供后续查询重用。即可重用性

结果集

SQL查询执行后返回的数据集合称为结果集,它包含了符合查询条件的所有行和列。

select sno,name from  student where class_id is not null

这个查询会返回一个结果集,其中包含student表中满足class_id不为空的所有行和sno、name列

  • 特点:
    • 包含了查询返回的实际数据,这些数据可以是来自一个或多个表的行和列的组合。
    • 结果集通常是临时的。一旦查询执行完毕,结果集就会被释放(除非它被存储在某个地方,如变量、临时表或文件中)。
    • 可处理性的。结果集可以在编程语言中通过API进行处理,如遍历、排序、筛选等。

总结

  • 存储与生成:

    虚拟表通常不存储实际数据,而是基于其他表或查询动态生成;
    结果集是查询执行后实际返回的数据集合。

  • 持久性

    虚拟表可以存储在数据库中供后续查询重用
    结果集通常是临时的,一旦查询完成就会被释放。

  • 用途

    虚拟表常用于简化复杂查询、提高查询可读性和可维护性;
    结果集则是查询执行后的直接输出,用于数据处理和展示。

嵌套查询在sql查询中的执行顺序

以下的代码都是简化的,我们假设有开窗函数、group by、having、order by、limit等限制

  • 在 select 子句中的嵌套查询

    SELECT  sno,(SELECT AVG(score) FROM student) AS average_score
    FROM  student;# 上述sql语句执行起来性能不是很高,咱们在这里只是仅作为举例分析,切勿较真哈
    # 对上述查询的优化如下:
    WITH AverageScore AS ( SELECT AVG(score) AS avg_score  FROM student)
    SELECT  s.sno,  a.avg_score AS average_score
    FROM  student s, AverageScore a;
    

    优先执行嵌套中的子查询,然后是外层的顺序,按照咱们上方介绍的来

  • 在 WHERE 子句中的嵌套查询

    SELECT  sno, name
    FROM  student
    WHERE  class_id IN (select id FROM class WHERE class_teacher is not null);
    

    优先执行嵌套中的子查询,然后是外层的顺序,按照咱们上方介绍的来

SELECT  sno, name
FROMselect * from newStudent where sex="女"as s
where age>=18

from本来就优先,from中的嵌套更得优先了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/12170.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【Android、IOS、Flutter、鸿蒙、ReactNative 】标题栏

Android 标题栏 参考 Android Studio版本 配置gradle镜像 阿里云 Android使用 android:theme 显示标题栏 添加依赖 dependencies {implementation("androidx.appcompat:appcompat:1.6.1")implementation("com.google.android.material:material:1.9.0")…

歌尔微拟赴港IPO,揭示AI+终端升级的供给革命

1959年,美国物理学家理查德费曼在他著名的演讲“底部有足够的空间”中,首次提出了将机器小型化到原子和分子尺度的想法。这个充满想象力的观点,为世界科技发展开启了一扇新的窗口。 时至今日,应这一理念而生的MEMS产品已经成为各…

ROS第七梯:ROS+VSCode+Python环境配置

第一步:Python版本的ROS项目和C++版本的ROS项目前期创建功能包的步骤基本一致,具体可参考第二章。 第二步:在功能包的目录下创建一个与src目录平级的文件夹,名称写作scripts: 第三步:在scripts文件夹下创建python的节点代码文件,此处以一个订阅节点代码文件为例:

洛谷解题日记||基础篇3

#include <iostream> #include <iomanip> // 用于设置输出格式 using namespace std;double a, b, c, d;// 定义方程 f(x) ax^3 bx^2 cx d double fc(double x) {return a * x * x * x b * x * x c * x d; }int main() {double l, r, m, x1, x2;int s 0;/…

软件测试学习记录 Day1

根据黑马程序员最新版的软件测试课程所做的笔记&#xff0c;需要原件后台私信&#xff1a; 练习提取测试点&#xff1a; 博主的答案&#xff0c;有不一样看法的可评论区讨论&#xff1a;

代码随想录刷题记录(二十七)——55. 右旋字符串

&#xff08;一&#xff09;问题描述 55. 右旋字符串&#xff08;第八期模拟笔试&#xff09;https://kamacoder.com/problempage.php?pid1065字符串的右旋转操作是把字符串尾部的若干个字符转移到字符串的前面。给定一个字符串 s 和一个正整数 k&#xff0c;请编写一个函数&…

FreeRTOS 24:事件组EventGroup等待、清零、获取操作

等待事件标志位xEventGroupWaitBits() 既然标记了事件的发生&#xff0c;那么我怎么知道他到底有没有发生&#xff0c;这也是需要一个函数来获 取 事 件 是 否 已 经 发 生 &#xff0c; FreeRTOS 提 供 了 一 个 等 待 指 定 事 件 的 函 数 — — xEventGroupWaitBits()&…

信息安全数学基础(47)域的结构

一、域的定义 设F为一个非空集合&#xff0c;在其上定义两种运算&#xff1a;加法和乘法。如果这两种运算在集合上封闭&#xff0c;且满足以下条件&#xff0c;则称F对于规定的乘法和加法构成一个域&#xff1a; F中所有元素对于加法形成加法交换群&#xff0c;即加法满足交换律…

#渗透测试#SRC漏洞挖掘#CSRF漏洞的防御

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…

HarmonyOS 沉浸式状态实现的多种方式

1. HarmonyOS 沉浸式状态实现的多种方式 HarmonyOS 沉浸式状态实现的多种方式 1.1. 方法一 1.1.1. 实现讲解 &#xff08;1&#xff09;首先设置setWindowLayoutFullScreen(true)&#xff08;设置全屏布局&#xff09;。   布局将从屏幕最顶部开始到最底部结束&#xff0c…

在API接口数据获取过程中,如何确保数据的安全性和隐私性?

在API接口数据获取过程中&#xff0c;确保数据的安全性和隐私性至关重要。以下是一些关键措施&#xff0c;可以帮助开发者和管理者保护API接口的数据安全和隐私性&#xff1a; 身份认证和授权 身份认证&#xff1a;确认用户身份的过程&#xff0c;常用的身份认证方式包括用户…

C++常用的特性-->day05

友元的拓展语法 声明一个类为另外一个类的友元时&#xff0c;不再需要使用class关键字&#xff0c;并且还可以使用类的别名&#xff08;使用 typedef 或者 using 定义&#xff09;。 #include <iostream> using namespace std;// 类声明 class Tom; // 定义别名 using …

python-27-Python ORM系列之彻底搞明白ORM概念,对ORM进行封装结合FastAPI实现数据库的增删改查,联表查询等接口

python-27-Python ORM系列之彻底搞明白ORM概念&#xff0c;对ORM进行封装结合FastAPI实现数据库的增删改查&#xff0c;联表查询等接口 一.简介 在Python基础系列ORM部分为大家介绍了如何搭建MySQL数据和MySQL一些访问配置&#xff0c;同时也介绍了pymysql库的封装来实现对数…

从哈佛哲学系到蛋白质设计大师,David Baker:AlphaFold令我深刻认识到深度学习的力量

要说谁是引领蛋白质设计的世界级大师&#xff0c;美国华盛顿大学的 David Baker 教授可谓是当之无愧&#xff0c;作为该领域的顶级专家&#xff0c;Baker 在蛋白质方向发表研究论文 700 余篇&#xff0c;引用量累计超 17.7 万。今年 10 月&#xff0c;因其在蛋白质设计方面的卓…

【测试框架篇】单元测试框架pytest(2):用例编写

一、 前言 前面一章我们介绍了pytest环境安装和配置&#xff0c;并在pycharm里面实现了我们第一个pytest脚本。但是有些童鞋可能在编写脚本的时候遇到了问题&#xff0c;本文会讲一下我们编写pytest用例时需要遵守哪些既定的规则&#xff0c;同时这个规则也是可以修改的。 二…

实现LiDAR和多视角摄像头数据的对齐、可控X-DRIVE:用于驾驶场景的跨模态一致多传感器数据合成

Abstract 近年来&#xff0c;扩散模型在合成驾驶场景中的LiDAR点云或摄像头图像数据方面取得了进展。尽管这些模型在单一模态数据的边际分布建模方面取得成功&#xff0c;但对不同模态之间互相依赖关系的探索仍然不足&#xff0c;而这种依赖关系能够更好地描述复杂的驾驶场景。…

稳恒磁场(1)

物理概念 磁场是物质性的。 地磁场&#xff08;与地磁场正负极相反&#xff09;与磁偏角&#xff08;一般为0到11度&#xff09; 磁感应强度&#xff1a; 单位为特斯拉&#xff08;T&#xff09;&#xff0c;另一个常用单位是高斯&#xff08;G&#xff09;且1T 10^4 G 物…

自动驾驶系列—自动驾驶中的短距离感知:超声波雷达的核心技术与场景应用

&#x1f31f;&#x1f31f; 欢迎来到我的技术小筑&#xff0c;一个专为技术探索者打造的交流空间。在这里&#xff0c;我们不仅分享代码的智慧&#xff0c;还探讨技术的深度与广度。无论您是资深开发者还是技术新手&#xff0c;这里都有一片属于您的天空。让我们在知识的海洋中…

多语言爬取淘宝价格信息 python 比价api接入指南

以下是爬取淘宝价格信息及接入淘宝比价 API 的一般步骤&#xff1a; 传统爬虫方式获取价格信息&#xff08;不建议大量使用&#xff0c;可能违反淘宝规定&#xff09;&#xff1a; 分析目标页面 URL&#xff1a;在淘宝搜索框输入关键词后&#xff0c;观察页面的 URL 结构。例如…

Java List——针对实习面试

目录 Java ListJava List的三种主要实现是什么&#xff1f;它们各自的特点是什么&#xff1f;Java List和Array&#xff08;数组&#xff09;的区别&#xff1f;Java List和Set有什么区别&#xff1f;ArrayList和Vector有什么区别&#xff1f;什么是LinkedList&#xff1f;它与…