【MySQL】探索 MySQL 中的 WITH 关键字:使用公共表表达式(CTE)简化查询


我已经从你的 全世界路过
像一颗流星 划过命运 的天空
很多话忍住了 不能说出口
珍藏在 我的心中
只留下一些回忆
                     🎵 牛奶咖啡《从你的全世界路过》


探索 MySQL 中的 WITH 关键字:使用公共表表达式(CTE)简化查询
在复杂的 SQL 查询中,特别是当涉及多次子查询或递归查询时,代码往往变得难以阅读和维护。为了解决这些问题,MySQL 8.0 引入了 WITH 关键字,用于定义公共表表达式(Common Table Expression,简称 CTE)。CTE 是一种可以简化复杂查询、提高可读性的强大工具。本文将详细介绍 MySQL 中 WITH 关键字的用法及其优势,并通过示例展示其实际应用。

什么是公共表表达式(CTE)?

公共表表达式(CTE)是一种在执行查询时临时存在的命名结果集。CTE 可以在查询中多次引用,从而避免重复编写相同的子查询。CTE 分为普通 CTE 和递归 CTE。

基本语法

普通 CTE 的基本语法如下:

WITH cte_name AS (-- 定义 CTE 的查询SELECT ...
)
SELECT ...
FROM cte_name;

递归 CTE 的基本语法如下:

WITH RECURSIVE cte_name AS (-- 基本部分(锚点)SELECT ...UNION ALL-- 递归部分SELECT ...FROM cte_nameWHERE ...
)
SELECT ...
FROM cte_name;

使用 CTE 的优势

提高查询的可读性和可维护性:通过使用 CTE,可以将复杂的查询逻辑分解为多个易于理解的部分。
避免重复代码:CTE 可以在查询中多次引用,减少了重复编写相同子查询的需求。
支持递归查询:递归 CTE 使得在 SQL 中处理层次结构数据变得更加简单和高效。

实际应用示例

示例 1:简化复杂查询

假设我们有一个 employees 表,结构如下:

CREATE TABLE employees (id INT PRIMARY KEY,name VARCHAR(50),manager_id INT
);

我们想查询每个员工的名字及其经理的名字。使用 CTE 可以简化查询逻辑:

WITH EmployeeManagers AS (SELECT e1.id, e1.name AS employee_name, e2.name AS manager_nameFROM employees e1LEFT JOIN employees e2 ON e1.manager_id = e2.id
)
SELECT * FROM EmployeeManagers;

在这个示例中,CTE EmployeeManagers 定义了一个包含员工及其经理名字的结果集,然后我们在外部查询中直接引用它。

示例 2:递归查询

递归 CTE 允许我们处理层次结构数据,例如组织结构或目录树。假设我们需要查询一个员工及其所有下属员工,使用递归 CTE 可以实现这一点:

WITH RECURSIVE EmployeeHierarchy AS (-- 基本部分(锚点):选择顶级员工SELECT id, name, manager_idFROM employeesWHERE manager_id IS NULLUNION ALL-- 递归部分:选择下属员工SELECT e.id, e.name, e.manager_idFROM employees eINNER JOIN EmployeeHierarchy eh ON e.manager_id = eh.id
)
SELECT * FROM EmployeeHierarchy;

在这个示例中,递归 CTE EmployeeHierarchy 首先选择没有经理的顶级员工,然后递归地选择下属员工,直到遍历整个组织结构。

示例 3:多重 CTE

有时,我们可能需要在查询中定义多个 CTE。可以通过逗号分隔多个 CTE 进行定义:

WITH DeptCTE AS (SELECT department_id, COUNT(*) AS employee_countFROM employeesGROUP BY department_id
),
HighSalaryCTE AS (SELECT id, name, salaryFROM employeesWHERE salary > 10000
)
SELECT d.department_id, d.employee_count, h.name, h.salary
FROM DeptCTE d
JOIN HighSalaryCTE h ON d.department_id = h.department_id;

在这个示例中,我们定义了两个 CTE:DeptCTE 用于计算每个部门的员工数量,HighSalaryCTE 用于选择高薪员工,然后在外部查询中结合这两个 CTE 进行查询。

结语

MySQL 中的 WITH 关键字和公共表表达式(CTE)是简化复杂查询、提高查询可读性和可维护性的强大工具。通过使用 CTE,我们可以将复杂的查询逻辑分解为多个易于理解和管理的部分,从而显著提高开发效率和代码质量。希望本文能帮助你更好地理解和应用 MySQL 中的 WITH 关键字,为你的数据库操作带来便利和优化。

Happy Querying!

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

按键精灵安装有乱码并且不能启动的解决办法

在国外购了电脑,系统是英文版 Windows 11,按键精灵死活都装不上去,打开exe的安装文件后出现乱码,安装完了后还是乱码,并且启动不了,以下是解决办法: 进入控制面板,并且点 Region&am…

MATLAB算法实战应用案例精讲-【数模应用】逐步回归分析(附MATLAB、R语言和python代码实现)

目录 前言 几个高频面试题目 逐步回归分析和多元线性回归的区别 知识储备 多元线性回归 模型选择 (Model Selection) 算法原理 什么是逐步回归分析 实现策略 向前选择 向后剔除 逐步回归 特征选择与逐步回归分析 2.1特征工程 2.2原始特征的问题 2.3降维与特征选…

汇编:结构体

在32位汇编中,结构体(structures)用于组织和管理复杂的数据类型,结构体可以包含多个不同类型的数据项(成员);在MASM(Microsoft Macro Assembler)中,使用结构体…

CentOS安装Node.js以及JSDOM跳坑记

笔者在一台 CentOS 7.9 的服务器上使用常规的安装命令:sudo yum install node 来安装 Node.js,到最后系统提示: Error: Package: 2:nodejs-20.14.0-1nodesource.x86_64 (nodesource-nodejs) Requires: libstdc.so.6(GLIBCXX_3.4.20)(64bit) …

vite获取所有环境变量(env)

0.环境变量文件 API_URL8888888 VITE_API_URL99999991.定义环境变量 默认情况下,vite只获取以VITE_为前缀的环境变量。 为了防止意外地将一些环境变量泄漏到客户端,只有以 VITE_ 为前缀的变量才会暴露给经过 vite 处理的代码 但如果你觉得你是进击的巨人…

VUE + nodejs实战

BVDN搭建 D: cd nodejs ::npm install bootstrap ::npm install jquery ::npm install popper.js ::npm install vue npm install vue-router pauseapp.html <!DOCTYPE html> <!DOCTYPE html> <html> <head><!--bootstrap--><link rel"…

vue面试题一

一、请解释Vue.js是什么&#xff1f; Vue.js 是一个构建用户界面的渐进式框架。它的核心库只关注视图层&#xff0c;不仅易于上手&#xff0c;也便于与第三方库或已有项目整合。Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件。 以下是 Vue.js 的一…

MySQL 5.7详细下载安装配置教程(MySQL 5.7安装包)_mysql5.7的安装教程

记录MySQL 5.7 的下载安装教程&#xff0c;并提供了Mysql 安装包 &#xff0c;以下是详细下载安装过程。 一、下载Mysql安装包 网盘下载&#xff1a; 下载MySQL 5.7安装包&#xff0c;网盘下载地址&#xff1a;点击此处直接下载 官网下载&#xff1a; 进入官网&#xff0c…

为什么选择Python作为AI开发语言

为什么Python适合AI 在当前的科技浪潮中&#xff0c;人工智能&#xff08;AI&#xff09;无疑是最热门的话题之一。无论是自动驾驶、智能推荐还是自然语言处理&#xff0c;AI都在不断改变我们的生活。而在这场技术革命中&#xff0c;Python作为主要的编程语言之一&#xff0c;…

python-win10跑通chattts笔记(亲测可跑)0.8.010

python-win10跑通chattts笔记-亲测可跑 背景项目地址安装过程使用技巧参考链接背景 克隆了项目中的代码,在无conda环境下使用pip安装了依赖,最后报错cl: 命令行 error D8021 :无效的数值参数“/Wno-register” error: command C:\,最后通过使用conda解决了,以此记录下 项…

构建LangChain应用程序的示例代码:27、FLARE:前瞻性主动检索增强生成技术实现与应用的示例

FLARE&#xff1a;前瞻性主动检索增强生成 这个示例是前瞻性主动检索增强生成&#xff08;FLARE&#xff09;的实现。 请查看原始仓库。 基本思想是&#xff1a; 开始回答问题如果开始生成模型不确定的标记&#xff0c;查找相关文档使用这些文档继续生成重复直到完成 在查…

【设计模式】行为型设计模式之 迭代器模式

介绍 迭代器模式&#xff08;Iterator Pattern&#xff09; 是行为设计模式之一&#xff0c;它提供了一种访问集合对象&#xff08;如列表、数组或其他集合结构&#xff09;中元素的方式&#xff0c;而不需要暴露集合的内部结构。迭代器模式定义了一个迭代器接口&#xff0c;该…

沪深历史行情下载,金融数据库查询

行情在线测试 在线测试 历史行情 jvQuant提供2008创立至今的历史股票行情数据&#xff0c;包含沪深主板、科创板、创业板&#xff0c;股票日内行情。 下载地址 http://jvquant.com/query/history?&token<token>&year<数据年份>.zip Copy 例:下载20…

K8S - 用kubectl远程访问内网的k8s集群

在之前的文章 K8S - 在任意node里执行kubectl 命令 介绍过&#xff0c; 通过任何node 的主机&#xff0c; 用kubectl 管理集群是很简单 无非就是两个步骤: 下载 k8s master 上的admin.conf在当前主机配置 K8SCONFIG 环境变量指向 下载的config file 其他内网主机也适用 其…

【Tools】探索动态隧道代理与普通代理:它们是什么,有何不同?

我已经从你的 全世界路过 像一颗流星 划过命运 的天空 很多话忍住了 不能说出口 珍藏在 我的心中 只留下一些回忆 &#x1f3b5; 牛奶咖啡《从你的全世界路过》 在互联网的世界中&#xff0c;代理服务器&#xff08;Proxy Server&#xff09;是一个重要的…

打字侠是一款PWA网站,如何下载到电脑桌面?

嘿&#xff0c;亲爱的键盘侠们&#xff01; 你是否还在为寻找一款好用的打字练习工具而烦恼&#xff1f;别担心&#xff0c;今天我要给大家介绍一位超级英雄——打字侠&#xff01;它不仅是一个超级酷的打字练习网站&#xff0c;还是一款PWA&#xff08;渐进式网页应用&#x…

在LUAT中使用MQTT客户端,游戏脚本,办公脚本自动操作

本文将介绍在LUAT中工程化使用MQTT客户端的方法及注意事项。实验平台为合宙AIR724UG&#xff0c;其固件版本为Luat_V4001_RDA8910_FLOAT_TMP。 面向对象 使用middleclass库为脚本提供基础面向对象支持&#xff0c;将此repo中的middleclass.lua文件添加到项目中即可使用。middl…

链路聚合LACP

#交换设备 链路聚合 理解链路聚合配置&#xff08;LACP) 什么是LACP LACP&#xff08;Link Aggregation Control Protocol&#xff0c;链路聚合控制协议&#xff09;是一种基于IEEE802.3ad标准的实现链路动态聚合与解聚合的协议&#xff0c;它是链路聚合中常用的一种协议。…

WEB-Wordlist-Generator:为扫描后的Web应用生成相关联的字典

关于WEB-Wordlist-Generator WEB-Wordlist-Generator是一款功能强大的字典生成工具&#xff0c;该工具旨在帮助广大研究人员扫描目标Web应用程序并生成与之相关联的字典文件&#xff0c;从而允许我们对相关的网络威胁行为执行预备性应对策略。 功能介绍 当前版本的WEB-Wordli…

微服务之远程调用

常见的远程调用方式 RPC&#xff1a;Remote Produce Call远程过程调用&#xff0c;类似的还有 。自定义数据格式&#xff0c;基于原生TCP通信&#xff0c;速度快&#xff0c;效率高。早期的webservice&#xff0c;现在热门的dubbo &#xff08;12不再维护、17年维护权交给apac…