SQL语句的执行顺序怎么理解?
SQL语句的执行顺序怎么理解?
我们常常会被SQL其书写顺序和执行顺序之间的差异所迷惑。理解这两者的区别,对于编写高效、可靠的SQL代码至关重要。今天,让我们用一些生动的例子和场景来深入探讨SQL的执行顺序。
一、书写顺序 VS 执行顺序
SQL语句的书写顺序遵循的是逻辑直观性,使人能够轻易理解和组织查询的内容。然而,它的执行顺序是基于数据库查询优化器的内部机制,旨在提高查询的效率。
书写顺序
我们通常按照以下顺序编写SQL语句:
SELECT
FROM
JOIN
WHERE
GROUP BY
HAVING
ORDER BY
LIMIT
执行顺序
而其执行顺序却是这样的:
FROM
ON
JOIN
WHERE
GROUP BY
(CUBE|ROLLUP)
HAVING
SELECT
DISTINCT
ORDER BY
LIMIT
二、深入理解执行顺序
FROM 和 JOIN(笛卡尔积、筛选器、外部行)
FROM
子句是查询的起点,用于确定基础表。JOIN
和ON
子句决定如何将这些表连接起来。
最近无意间获得一份阿里大佬写的刷题笔记,一下子打通了我的任督二脉,进大厂原来没那么难。
这是大佬写的, 7701页的BAT大佬写的刷题笔记,让我offer拿到手软
WHERE(筛选行)
WHERE
子句过滤掉不符合条件的行。
GROUP BY(分组)
GROUP BY
对符合条件的行进行分组。
HAVING(分组后筛选)
HAVING
子句筛选分组后的结果。
SELECT 和 DISTINCT(选择与去重)
SELECT
确定最终展示的列。DISTINCT
用于去除重复的行。
ORDER BY 和 LIMIT(排序和限制)
ORDER BY
对结果进行排序。LIMIT
限制返回的行数。
三、实际案例分析
1. 基础查询
考虑一个简单的查询:
SELECT name, age
FROM users
WHERE age > 30
ORDER BY age;
这个查询首先从users
表中选择年龄大于30的记录(FROM
和WHERE
),然后选择name
和age
列(SELECT
),最后按年龄排序(ORDER BY
)。
2. JOIN查询
涉及JOIN的复杂查询:
SELECT u.name, u.age, o.order_id
FROM users u
JOIN orders o ON u.user_id = o.user_id
WHERE u.age > 30
ORDER BY o.order_date;
在这个例子中,我们首先确定了两个表(FROM users
和JOIN orders
),根据用户ID将它们连接起来(ON u.user_id = o.user_id
),过滤出年龄大于30的用户(WHERE
),然后选择特定的列进行展示(SELECT
),最后按订单日期排序(ORDER BY
)。
3. 性能优化场景
假设有一个大型的用户表和订单表,我们需要有效地查询某个年龄段的用户及其订单。正确理解执行顺序有助于我们优化这个查询,例如,首先过滤出特定年龄段的用户,然后再去JOIN订单表,这样可以显著减少JOIN的计算量。
四、ORDER BY的特殊情况
在你提出的问题中,ORDER BY按照SCORE
列排序,但SELECT
子句中并没有选择这一列。这是一个常见的误区。实际上,在执行ORDER BY
时,数据库会考虑所有的列,即使这些列没有在SELECT
子句中明确指出。因此,即使SCORE
列在SELECT
子句中没有出现,它仍然可以用于排序。
五、使用聚合函数
考虑这样一个查询:我们想要找出每个部门平均工资最高的前三名员工。
SELECT department_id, employee_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id, employee_id
HAVING AVG(salary) > 10000
ORDER BY department_id, avg_salary DESC
LIMIT 3;
在这个查询中,我们首先从employees
表中选择数据(FROM
),根据department_id
和employee_id
进行分组(GROUP BY
),只选择平均工资超过10000的组(HAVING
),然后选择部门ID、员工ID和平均工资(SELECT
),按部门排序且工资降序(ORDER BY
),最后选择每个部门的前三名(LIMIT
)。
六、多表连接
假设我们需要查询所有顾客的订单信息,包括顾客姓名和订单细节。
SELECT c.name, o.order_details
FROM customers c
JOIN orders o ON c.id = o.customer_id
WHERE o.order_date > '2023-01-01'
ORDER BY c.name, o.order_date;
这个查询首先确定了连接customers
和orders
表(FROM
和JOIN
),根据顾客ID连接(ON
),筛选出2023年1月1日之后的订单(WHERE
),选择顾客姓名和订单详情(SELECT
),并按顾客姓名和订单日期排序(ORDER BY
)。
最近无意间获得一份阿里大佬写的刷题笔记,一下子打通了我的任督二脉,进大厂原来没那么难。
这是大佬写的, 7701页的BAT大佬写的刷题笔记,让我offer拿到手软
七、子查询
子查询可以用于多种场合,比如在WHERE
子句中筛选记录。
SELECT name, age
FROM users
WHERE id IN (SELECT user_id FROM orders WHERE order_date > '2023-01-01')
ORDER BY age;
在这个例子中,SELECT
子查询首先找出2023年1月1日之后下单的用户ID,然后外层查询根据这些ID选择用户的名字和年龄(FROM
和WHERE
),最后按年龄排序(ORDER BY
)。
八、使用CASE语句
CASE
语句可以用来在查询中添加逻辑。
SELECT name, CASE WHEN age < 20 THEN '少年'WHEN age BETWEEN 20 AND 60 THEN '成年'ELSE '老年'END AS age_group
FROM users
ORDER BY age;
这里,CASE
语句根据年龄分组(在SELECT
中处理),首先从users
表选择数据(FROM
),然后按年龄排序(ORDER BY
)。
九、窗口函数
窗口函数可以用来执行复杂的数据分析任务。
SELECT name, age, RANK() OVER (PARTITION BY department ORDER BY salary DESC) AS rank
FROM employees;
在此查询中,RANK()
窗口函数被用来计算每个部门内员工的工资排名(在SELECT
中处理),首先选择所有员工(FROM
),没有指定特别的排序或限制条件。
这些SQL案例中,可以提炼出几个关键的最佳实践和技巧
1. 优化数据筛选(WHERE和JOIN)
- 有效使用WHERE子句:在连接表格前先用WHERE子句过滤掉不需要的数据,可以减少处理的数据量,从而提高查询效率。
- 明智选择JOIN类型:根据查询需求选择合适的JOIN类型(INNER JOIN, LEFT JOIN, RIGHT JOIN等),可以有效控制结果集的大小和准确性。
2. 熟练使用聚合和分组(GROUP BY和HAVING)
- 合理使用聚合函数:在GROUP BY子句中使用聚合函数(如AVG, SUM, COUNT等)可以有效地对数据进行总结和分析。
- 精确过滤分组结果:HAVING子句用于过滤分组后的结果,特别是在处理聚合数据时,它比WHERE子句更加灵活。
3. 掌握数据排序和限制(ORDER BY和LIMIT)
- 有效利用ORDER BY:正确使用ORDER BY子句可以确保结果集按照特定的顺序返回,这对于报告和用户界面显示非常重要。
- 合理应用LIMIT:LIMIT子句非常有用,尤其是在处理大数据集时,它可以限制返回的结果数量,加快查询速度并减少内存消耗。
4. 灵活应用子查询和CASE语句
- 子查询的强大功能:子查询可以在主查询之前或之内执行,使得SQL语句更加强大和灵活。
- 使用CASE语句进行条件逻辑处理:CASE语句可以在SELECT、WHERE和ORDER BY子句中使用,实现复杂的条件逻辑。
5. 理解窗口函数
- 窗口函数的应用:窗口函数(如RANK, ROW_NUMBER等)可以用于执行复杂的数据分析和处理,如排名、分区数据处理等。
6. 性能优化
- 索引的重要性:合理使用索引可以显著提高查询效率,尤其是在大数据量的表上。
- 避免不必要的复杂性:过于复杂的JOIN和子查询可能导致性能下降,应当避免不必要的复杂性。
7. 清晰易懂的代码
- 代码可读性:写出清晰、易于理解的SQL代码对于维护和团队协作非常重要。
通过运用这些技巧,你可以编写出既高效又易于理解的SQL查询,这对于处理各种数据分析和数据库操作任务至关重要。记住,良好的SQL实践不仅仅关乎代码本身,还涉及到如何在特定的数据环境中最有效地运用这些代码。
推荐一个学习 MySQL 的专栏
- 01、MySQL MariaDB 基础教程
- 02、MySQL 简介
- 03、MySQL MariaDB 安装
- 04、MySQL 管理
- 05、MySQL 日常管理
- 06、MySQL PHP 语法
- 07、MySQL 创建连接
- 08、MySQL 获取数据库列表
- 09、MySQL 创建数据库
- 10、MySQL 删除数据库
- 11、MySQL 选择数据库
- 12、MySQL 数据类型
- 13、MySQL 列出数据表
- 14、MySQL 创建数据表
- 15、MySQL 删除表
- 16、MySQL 插入数据
- 17、MySQL 获取插入数据的 ID
- 18、MySQL SELECT FROM 查询数据
- 19、MySQL WHERE 子句有条件的查询数据
- 20、MySQL UPDATE 更新数据
- 21、MySQL DELETE FROM 语句删除数据
- 22、MySQL 返回删改查受影响的行数
- 23、MySQL LIKE 子句模糊查询数据
- 24、MySQL UNION 操作符查询多张表
- 25、MySQL ORDER BY 排序
- 26、MySQL GROUP BY 分组查询数据
- 27、MySQL JOIN 进行多表查询
- 28、MySQL NULL 值处理
- 29、MySQL REGEXP 子句正则表达式查询
- 30、MySQL 数据库事务
- 31、MySQL ALTER 命令
- 32、MySQL 索引
- 33、CREATE TEMPORARY TABLE 创建临时表
- 34、MySQL DROP TABLE 删除临时表
- 35、MySQL INSERT INTO SELECT 复制表
- 36、MySQL 获取服务器元数据
- 37、MySQL 自增序列 AUTO_INCREMENT
- 38、MySQL 处理重复数据
- 39、MySQL 安全及防止 SQL 注入攻击
- 40、MySQL 导出数据
- 41、MySQL 导入数据
总结
理解SQL的执行顺序不仅能帮助我们写出更有效的查询,还能让我们更好地理解数据库是如何处理我们的请求的。通过实际案例的分析和理解,我们可以更好地掌握SQL查询的艺术。记住,每一条SQL语句都像是一次小小的旅行,从FROM
出发,经过一系列的处理,最终到达SELECT
的归宿。
在SQL的世界里,旅途的顺序和规划同样重要,它决定了查询的效率和准确性。我们要做的,就是成为这个旅程的优秀规划师。
最后说一句(求关注,求赞,别白嫖我)
最近无意间获得一份阿里大佬写的刷题笔记,一下子打通了我的任督二脉,进大厂原来没那么难。
这是大佬写的, 7701页的BAT大佬写的刷题笔记,让我offer拿到手软
项目文档&视频:
项目文档 & 视频
本文,已收录于,我的技术网站 ddkk.com,有大厂完整面经,工作技术,架构师成长之路,等经验分享
求一键三连:点赞、分享、收藏
点赞对我真的非常重要!在线求赞,加个关注我会非常感激!@架构师专栏
相关文章:
SQL语句的执行顺序怎么理解?
SQL语句的执行顺序怎么理解? 我们常常会被SQL其书写顺序和执行顺序之间的差异所迷惑。理解这两者的区别,对于编写高效、可靠的SQL代码至关重要。今天,让我们用一些生动的例子和场景来深入探讨SQL的执行顺序。 一、书写顺序 VS 执行顺序 SQ…...
js解析.shp文件
效果图 原理与源码 本文采用的是shapefile.js工具 这里是他的npm地址 https://www.npmjs.com/package/shapefile 这是他的unpkg地址,可以点开查看源码 https://unpkg.com/shapefile0.6.6/dist/shapefile.js 这个最关键的核心问题是如何用这个工具,网上…...
关于“Python”的核心知识点整理大全25
目录 10.3.4 else 代码块、 10.3.5 处理 FileNotFoundError 异常 alice.py 在这个示例中,try代码块引发FileNotFoundError异常,因此Python找出与该错误匹配的 except代码块,并运行其中的代码。最终的结果是显示一条友好的错误消息&#x…...
代码随想录刷题题Day15
刷题的第十五天,希望自己能够不断坚持下去,迎来蜕变。😀😀😀 刷题语言:C Day15 任务 ● 513.找树左下角的值 ● 112. 路径总和 113.路径总和ii ● 106.从中序与后序遍历序列构造二叉树 105.从前序与中序遍历…...
软件设计师——信息安全(一)
📑前言 本文主要是【信息安全】——软件设计师——信息安全的文章,如果有什么需要改进的地方还请大佬指出⛺️ 🎬作者简介:大家好,我是听风与他🥇 ☁️博客首页:CSDN主页听风与他 🌄…...
git必须掌握:git远程变动怎么解决
如何已经指定了选择分支 那下面的分支名称可以省略 如果远程分支存在变动,通常 git 推送的流程如下: 首先,使用 git fetch 命令从远程仓库获取最新的分支信息和变动。 git fetch然后,可以使用 git merge 或者 git rebase 命令进…...
Python里的时间模块
time 模块 时间表示方式 时间戳 timestamp:表示的是从 1970 年1月1日 00:00:00 开始按秒计算的偏移量UTC(Coordinated Universal Time, 世界协调时)亦即格林威治天文时间,世界标准时间。在中国为 UTC+8 DST(Daylight Saving Time) 即夏令时;结构化时间(struct_time): …...
SCI一区级 | Matlab实现GWO-CNN-GRU-selfAttention多变量多步时间序列预测
SCI一区级 | Matlab实现GWO-CNN-GRU-selfAttention多变量多步时间序列预测 目录 SCI一区级 | Matlab实现GWO-CNN-GRU-selfAttention多变量多步时间序列预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 1.Matlab实现GWO-CNN-GRU-selfAttention灰狼算法优化卷积门控循环…...
C#学习相关系列之自定义遍历器
在C#中,自定义遍历器需要实现IEnumerable接口和IEnumerator接口。其中,IEnumerable接口包含一个GetEnumerator方法,该方法返回一个IEnumerator接口的实例,而IEnumerator接口包含Current、MoveNext和Reset方法。 IEnumerable&#…...
WPS没保存关闭了怎么恢复数据?3个方法,完成数据恢复!
“我今天在使用WPS时,突然有点急事出去了一趟,但是我忘记保存文档了,回来之后发现电脑自动关机了,我的文档也没了!这可怎么办呢?有什么办法可以找回这些数据吗?” 在快节奏的工作中,…...
数据结构和算法-最小生成树(prim和krusakal)和最短路径问题(BFS和dijkastra和floyd)
文章目录 最小生成树总览生成树广度优先生成树深度优先生成树最小生成树Prim算法Kruskal算法Prim vs KrusakalPrim的实现Kruskal的实现 小结 最短路径问题单源最短路径问题BFS求无权图的单源最短路径小结Dijkastra算法算法时间复杂度不适用情况 每一对顶点的最短路径问题Floyd算…...
响应者链概述
响应者链 iOS事件的3大类型 Touch Events(触摸事件)Motion Events(运动事件,比如重力感应和摇一摇等)Remote Events(远程事件,比如用耳机上得按键来控制手机) 触摸事件 处理触摸事件的两个步骤 寻找事件的最佳响应者事件的响应在响应链中的传递 寻…...
ShenYu网关Http服务探活解析
文章目录 网关端服务探活admin端服务探活 Shenyu HTTP服务探活是一种用于检测HTTP服务是否正常运行的机制。它通过建立Socket连接来判断服务是否可用。当服务不可用时,将服务从可用列表中移除。 网关端服务探活 以divide插件为例,看下divide插件是如何获…...
基于dockerfile搭建LNMP
组件自定义IP所需组件nginx172.111.0.10nginxwordpressmysql172.111.0.20mysql-5.7.20php172.111.0.30php LNMP介绍 L:Linux平台,操作系统,另外桑组件的运行平台 N:nginx 提供前端页面 M:MySQL,开源关系的…...
基于VGG-16+Android+Python的智能车辆驾驶行为分析—深度学习算法应用(含全部工程源码)+数据集+模型(三)
目录 前言总体设计系统整体结构图系统流程图 运行环境模块实现1. 数据预处理2. 模型构建3. 模型训练及保存1)模型训练2)模型保存 4. 模型生成1)模型导入及调用2)相关代码(1)布局文件(2ÿ…...
springMVC-@RequestMapping
基本介绍 RequestMapping注解可以指定控制器/处理器的某个方法的请求的url, 示例 (结合springMVC基本原理理解) Controller public class UserHandler {RequestMapping(value "/login")public String login() {System.out.println("登…...
智能优化算法应用:基于树种算法3D无线传感器网络(WSN)覆盖优化 - 附代码
智能优化算法应用:基于树种算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于树种算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.树种算法4.实验参数设定5.算法结果6.参考文献7.MA…...
web前端项目-影视网站开发
影视网站 本项目主要使用到了 HTML;CSS;JavaScript脚本技术;AJAX无刷新技术;jQuery等技术实现了动态影视网页 运行效果: 一:index.html <!DOCTYPE> <html lang"en"> <head>…...
QT:Unable to create a debugging engine.
debug跑不了: 报错:Unable to create a debugging engine. 参考: https://blog.csdn.net/u010906468/article/details/104716198 先检查是否安装了DEBUG插件 工具-》》选项 查看插件,如果没有的话,需要重新安装qt时…...
如何理解Rust语言中的“impl”关键字
在Rust编程语言中,impl是一个关键字,用于为类型实现方法和特性(traits)。impl关键字后面可以跟一个类型或者特性名称,然后在大括号中定义该类型或特性的具体实现。 当我们使用impl关键字为一个类型实现方法时…...
C++实现简单的猜数字小游戏
猜数字 小游戏介绍:猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了,还是小了,相等表示猜到了。如果猜到&…...
人工智能导论复习资料
题型 1、简答题(5题) 2、设计题 3、综合题 4、论述题(10分) 考点 第一章 1、人工智能的定义、发展; 2、人工智能的学派、认知观及其间的关系; 3、人工智能要素及系统分类; 4、人工智能的研究、…...
Sentinel使用详解
组件简介 Sentinel是阿里开源的一套用于服务容错的综合性解决方案。它以流量为切入点,从流量控制、熔断降级、系统负载保护等多个维度来保护服务的稳定性。Sentinel承接了阿里巴巴近10年的双十一大促流量的核心场景,例如秒杀、消息削峰填谷、集群流量控…...
Vue3源码梳理:响应式系统的前世今生
响应性数据的前世 js的程序性: 一套固定的,不会发生变化的执行流程 1 )没有响应的数据 // 定义商品对象 const product {price: 10,quantity: 2 }// 总价格 let total product.price * product.quantity console.log(总价格:${total}) //…...
Jetpack Compose开发一个Android WiFi导航应用
在以前的一篇文章构建一个WIFI室内定位系统_wifi定位系统-CSDN博客中,我介绍了如何用Android来测量WiFi信号,上传到服务器进行分析后,生成室内不同地方的WiFi指纹,从而帮助进行室内导航。当时我是用的HTML5的技术来快速开发一个An…...
【Mode Management】ComM详细介绍
目录 1. Introduction and functional overview 2.Dependencies to other modules 3.Functional specification 3.1 Partial Network Cluster Management 3.2 ComM channel state machine 3.2.1 Behaviour in state COMM_NO_COMMUNICATION 3.2.1.1 COMM_NO_COM_NO_PENDI…...
【C++多线程编程】(二)之详解锁(lock)和解锁(unlock)
在C多线程编程中,锁(lock)和解锁(unlock)通常用于管理共享资源的访问,以防止多个线程同时对资源进行修改,从而避免竞态条件(Race Condition)和数据不一致性问题。C标准库…...
【Mypy】超级实用的python高级库!
今天,我很兴奋地向大家介绍一个神奇的Python库:Mypy。这个库是Python世界中的一颗璀璨明星,提供了静态类型检查的强大功能,极大地增强了Python这门动态类型语言的健壮性和可维护性。我们将深入探索Mypy的多个方面,并通…...
【Python基础】循环语句
文章目录 [toc]什么是循环Python中的循环方式while循环格式示例 什么是循环 程序中需要重复执行的代码,可以通过循环实现比如和女朋友道歉,或一万遍“宝宝,我错了”,在没有学习循环之前,我们只能通过如下方式实现 pr…...
【面试】广告优化
a1:点击率公式是什么?点击率低的原因是什么? 点击率点击/曝光,点击率低的原因主要有两点:一是创意不吸引人;二是目标受众不准确/定向过宽不精确,广告曝光给了对产品不感兴趣用户 a2:…...
公司网站开发/怎么制作个人网站
1.避免在索引列上使用NOT和!,索引只能告诉我们什么存在与表中,不能告诉我们什么不存在表中 2.索引列上用>替代> 3.oracle采用自下而上的顺序解析where子句,因此表之间的连接必须放在其他where条件之前,那些可以过…...
广西建设工会网站/防恶意竞价点击软件
阿里云服务器 发送邮箱 STMP 25端口 465端口问题 PHPMailer是一个用于发送电子邮件的PHP函数包。它提供的功能包括: *.在发送邮时指定多个收件人,抄送地址,暗送地址和回复地址*.支持多种邮件编码包括:8bit,base64&…...
团购网站做二级域名/独立站seo优化
注意:单击此处https://urlify.cn/AJbIRb下载完整的示例代码,或通过Binder在浏览器中运行此示例显示收缩(shrinkage)是如何改善分类效果。sphx_glr_plot_lda_001import numpy as npimport matplotlib.pyplot as pltfrom sklearn.datasets import make_blo…...
怎么在服务器中安装WordPress/南京seo优化推广
我们在做接口测试时,除了常见的http接口,还有一种比较多见,就是socket接口,今天讲解下怎么用Python进行websocket接口测试。现在大多数用的都是websocket,那我们就先来安装一下websocket的安装包。pip install websock…...
iis 发布网站 500/百度手机助手app下载安装
如果运行一些程序后,远行yum命令出现“rpmdb: Lock table is out of available locker entries...”的问题时, 你可以按照如下操作来修复它:错误表现如下:rpmdb: Lock table is out of available locker entrieserror: db4 error(22) from db->close:…...
冰燃建站/无锡网站建设方案优化
引言前段时间在作信号分析处理方面的项目时,需要将时域数据通过快速傅立叶变换(FFT)转换到频域以便作进一步的后续处理,由于涉及到实时运算速度方面的要求,需要考虑程序算法的运算性能问题,因此,信号处理算法是在C语言…...