当前位置: 首页 > article >正文

使用 SQL CTE(公共表表达式)优化数据查询的实践

目录

一、背景

二、什么是 CTE?

三、CTE 的基本结构

四、示例分析

五、CTE 的作用

六、优势分析


一、背景

在数据分析和数据库管理中,SQL 查询的效率和可读性是至关重要的。随着数据量的不断增加,复杂的查询变得越来越难以管理和理解。为了解决这个问题,SQL 提供了一种强大的工具——公共表表达式(CTE,Common Table Expressions)

二、什么是 CTE?

公共表表达式(CTE)是一种临时结果集,可以在 SQL 查询的执行过程中使用。CTE 通过 WITH 关键字定义,允许开发者在主查询中引用该结果集。CTE 的主要优点在于它可以使复杂的查询更易于理解和维护,同时提高查询的可读性。

三、CTE 的基本结构

CTE 的基本结构如下:

WITH CTE_Name AS (SELECT ...
)
SELECT ...
FROM CTE_Name;

在这个结构中,CTE_Name 是 CTE 的名称,后面的 SELECT 语句可以引用这个临时结果集。

四、示例分析

让我们通过一个具体的 SQL 查询来深入理解 CTE 的作用。以下是一个使用 CTE 的查询示例:

WITH BaseData AS (SELECT*,CASEWHEN system_type = 'TypeA' AND response_type IN ('1', '2') THEN 'CategoryA'WHEN system_type = 'TypeB' AND response_type IN ('1', '2') THEN 'CategoryB'ELSE 'Other'END AS category_type,CASEWHEN region = 'Region1' THEN 'Region1'WHEN region = 'Region2' THEN 'Region2'ELSE 'Unknown Region'END AS regionFROM some_tableWHERE created_time BETWEEN '2025-01-01' AND '2025-01-31'
),
FilteredData AS (SELECTregion,category_type,response_item,project_detailsFROM BaseDataWHERE category_type IN ('CategoryA', 'CategoryB')
)
SELECTregion,category_type,COUNT(CASE WHEN response_item = '1001' THEN 1 END) AS inquiry_type1,COUNT(CASE WHEN response_item = '1002' THEN 1 END) AS inquiry_type2,COUNT(CASE WHEN response_item = '1003' THEN 1 END) AS inquiry_type3
FROM FilteredData
GROUP BY region, category_type;

五、CTE 的作用

在这个查询中,CTE 被分为两个部分:BaseData 和 FilteredData。

  1. BaseData CTE

首先,从 some_table 表中提取数据,并根据特定条件生成两个新的列:category_type 和 region。这一步骤通过 CASE 语句实现了数据的分类和区域映射。通过在 CTE 中进行这些操作,查询的逻辑变得更加清晰,便于后续的处理。

  1. FilteredData CTE

接下来,从 BaseData 中筛选出 category_type 为“CategoryA”或“CategoryB”的记录。这一过程确保后续分析只关注这两类数据,进一步简化了查询。

六、优势分析

使用 CTE 的主要优势包括:

  • 提高可读性:通过将复杂的查询分解为多个简单的部分,CTE 使得 SQL 查询更易于理解。开发者可以清晰地看到每个步骤的目的和结果。
  • 简化维护:当查询逻辑需要更改时,CTE 使得修改变得更加简单。开发者只需更新 CTE 的定义,而不必在整个查询中查找和替换。
  • 避免重复计算:在 CTE 中定义的结果集可以在后续查询中多次引用,避免了重复计算,提高了查询效率。

相关文章:

使用 SQL CTE(公共表表达式)优化数据查询的实践

目录 一、背景 二、什么是 CTE? 三、CTE 的基本结构 四、示例分析 五、CTE 的作用 六、优势分析 一、背景 在数据分析和数据库管理中,SQL 查询的效率和可读性是至关重要的。随着数据量的不断增加,复杂的查询变得越来越难以管理和理解。…...

旅游CMS选型:WordPress、Joomla与Drupal对比

内容概要 在旅游行业数字化转型进程中,内容管理系统(CMS)的选择直接影响网站运营效率与用户体验。WordPress、Joomla和Drupal作为全球主流的开源CMS平台,其功能特性与行业适配性存在显著差异。本文将从旅游企业核心需求出发&…...

全面适配iOS 18.4!通付盾加固产品全面升级,护航App安全上架

引言: 苹果官方新规落地! 自2025年4月24日起,所有提交至App Store Connect的应用必须使用Xcode 16或更高版本构建,否则将面临审核驳回风险!Beta版iOS 18.4、iPadOS 18.4现已推出,通付盾iOS加固产品率先完成…...

bash 和 pip 是两种完全不同用途的命令,分别用于[系统终端操作]和[Python 包管理]

bash 和 pip 是两种完全不同用途的命令,分别用于 系统终端操作 和 Python 包管理。以下是它们的核心区别、用法及常见场景对比: 1. 本质区别 特性bashpip类型Shell 命令解释器(一种脚本语言)Python 包管理工具作用执行系统命令、…...

SQL 通用表表达式(CTE )

目录 概念:CTE: Common table Expression CTE 语法 CTE Demo 概念:CTE: Common table Expression 通用表表达式(CTE)是SQL中用于简化复杂查询的工具,第一次上线于SQL Server 2005。 CTE提供…...

一台电脑最多能接几个硬盘?

在使用电脑时,硬盘空间不够是许多用户都会遇到的问题。无论是摄影师、剪辑师等需要大量存储空间的专业人士,还是游戏玩家、数据备份爱好者,都可能希望通过增加硬盘来扩展存储容量。然而,一台电脑究竟最多能接多少个硬盘&#xff1…...

MATLAB中iscell函数用法

目录 语法 说明 示例 确定数组是否为元胞数组 iscell函数的功能是确定输入是否为元胞数组。 语法 tf iscell(A) 说明 如果 A 是元胞数组,则 tf iscell(A) 返回 1 (true)。否则,将返回 0 (false)。 示例 确定数组是否为元胞数组 创建一个元胞数…...

【玩转全栈】---- Django 基于 Websocket 实现群聊(解决channel连接不了)

学习视频: 14-11 群聊(一)_哔哩哔哩_bilibili 目录 Websocket 连接不了? 收发数据 断开连接 完整代码 聊天室的实现 聊天室一 聊天室二 settings 配置 consumer 配置 多聊天室 Websocket 连接不了? 基于这篇博客&…...

如何快速解决django报错:cx_Oracle.DatabaseError: ORA-00942: table or view does not exist

我们在使用django连接oracle进行编程时,使用model进行表映射对接oracle数据时,默认表名组成结构为:应用名_类名(如:OracleModel_test),故即使我们库中存在表test,运行查询时候&#…...

Selenium之简介

Selenium简介 首先,让我们看看官网是怎么定义的 Selenium是一个支持web浏览器自动化的一系列工具和库的综合项目,提供了扩展来模拟用户和浏览器的交互,用于扩展浏览器分配的分发服务器;用于W3C WebDriver规范的基础架构 其实&a…...

pip 安装某个包之后,Jupyter Lab仍旧显示包冲突;例如:Numba needs NumPy 2.1 or less. Got NumPy 2.2.

异常提示 Numba needs NumPy 2.1 or less. Got NumPy 2.2. --------------------------------------------------------------------------- ImportError Traceback (most recent call last) Cell In[8], line 53 import pywt4 import matplot…...

本地安装git

下载git 通过官网 下载 :Git - Downloading Package 若此页面无法直达,请删掉download/win尝试 2.双击运行安装 选择安装目录: 选择配置,默认不动 git安装目录名 默认即可 Git 的默认编辑器,建议使用默认的 Vim 编辑器…...

小程序内表格合并功能实现—行合并

功能介绍:支付宝小程序手写表格实现行内合并,依据动态数据自动计算每次需求合并的值,本次记录行内合并,如果列内合并,同理即可实现 前端技术:grid布局 display:grid 先看实现效果: axml&…...

SSE协议介绍和python实现

概述: SSE(Server-Sent Events)协议是一种允许服务器向客户端实时推送更新的技术,基于HTTP协议,常用于实时数据推送特点: 单向通信:服务器向客户端推送数据,客户端无法发送数据。基…...

甘肃旅游服务平台+论文源码视频演示

4 系统设计 4.1系统概要设计 甘肃旅游服务平台并没有使用C/S结构,而是基于网络浏览器的方式去访问服务器,进而获取需要的数据信息,这种依靠浏览器进行数据访问的模式就是现在用得比较广泛的适用于广域网并且没有网速限制要求的小程序结构&am…...

Spring Boot 3虚拟线程的使用

在Spring Boot非Web应用中,使用虚拟线程时程序提前终止的问题及解决方案,可以通过以下步骤深入理解和验证: 问题根源分析 JVM退出机制 Java中,当所有非守护线程结束时,JVM会立即退出。即使存在正在运行的守护线程&…...

3、pytest实现参数化

在 pytest 中,参数化(parametrization)是一种强大的功能,可以让你用不同的输入数据重复执行同一个测试函数。这种功能非常有用,可以帮助你显著减少重复代码并提高测试覆盖率。 参数化的主要作用是: 测试多…...

【解决】Linux命令报错:Cannot find a valid baseurl for repo: centos-sclo-rh/x86_64

报错命令 yum install zabbix-web-mysql-scl zabbix-apache-conf-scl centos使用scl切换软件版本时提示Cannot find a valid baseurl for repo: centos-sclo-rh/x86_64 报错原因 CentOS7的SCL源在2024年6月30日停止维护了。 当scl源里面默认使用了centos官方的地址&#x…...

WebRTC中音视频服务质量QoS之FEC+NACK调用流程

WebRTC中音视频服务质量QoS之FECNACK调用流程 WebRTC中音视频服务质量QoS之FECNACK调用流程 WebRTC中音视频服务质量QoS之FECNACK调用流程前言一、WebRTC中FEC基础原理1. FEC基础操作 异或操作XOR2、 FEC中 行向和纵向 计算3、 WebRTC中 媒体包分组和生成FEC的包数① kFecRateT…...

神经网络知识点整理

目录 ​一、深度学习基础与流程 二、神经网络基础组件 三、卷积神经网络(CNN)​编辑 四、循环神经网络(RNN)与LSTM 五、优化技巧与调参 六、应用场景与前沿​编辑 七、总结与展望​编辑 一、深度学习基础与流程 机器学习流…...

远程办公新体验:用触屏手机流畅操作电脑桌面

在数字化浪潮的推动下,远程办公已从“应急选项”转变为职场常态。无论是居家隔离、差旅途中,还是咖啡厅临时办公,高效连接公司电脑的需求从未如此迫切。然而,传统的远程控制软件常因操作复杂、画面卡顿或功能限制而影响效率。如今…...

【面试八股】:常见的锁策略

常见的锁策略 synchronized (标准库的锁不够你用了)锁策略和 Java 不强相关,其他语言涉及到锁,也有这样的锁策略。 1. 悲观锁,乐观锁(描述的加锁时遇到的场景) 悲观锁:预测接下来…...

【python】OpenCV—Hand Detection

文章目录 1、功能描述2、代码实现3、效果展示4、完整代码5、参考6、其它手部检测和手势识别的方案 更多有趣的代码示例,可参考【Programming】 1、功能描述 基于 opencv-python 和 mediapipe 进行手部检测 2、代码实现 导入必要的库函数 import cv2 import media…...

es6的100个问题

基础概念 解释 let、const 和 var 的区别。什么是块级作用域?ES6 如何实现它?箭头函数和普通函数的主要区别是什么?解释模板字符串(Template Literals)的用途,并举例嵌套变量的写法。解构赋值的语法是什么…...

【Git 常用指令速查表】

Git 常用指令速查表 Git 常用指令速查表目录1. 初始化仓库2. 提交代码流程3. 分支管理4. 远程仓库操作5. 撤销操作6. 查看状态与日志7. 其他实用指令完整操作示例常用场景速查表 Git 常用指令速查表 目录 初始化仓库提交代码流程分支管理远程仓库操作撤销操作查看状态与日志其…...

Flink中聚合算子介绍

前言 在flink api中,聚合算子是非常常用的。所谓的聚合就是在分组的基础上做比较计算的操作。下面通过几个简单案例来说明聚合算子的用法和注意事项。 聚合算子案例 因为flink的api操作流程比较固定,从获取执行环境》获取数据源》执行数据转换操作》输…...

【基础】Windows 中通过 VSCode 使用 GCC 编译调试 C++

准备 安装 VSCode 及 C 插件。通过 MSYS2 安装 MinGW-w64 工具链,为您提供必要的工具来编译代码、调试代码并配置它以使用IntelliSense。参考:Windows 中的 Linux 开发工具链 验证安装: gcc --version g --version gdb --version三个核心配…...

Web Services 简介

Web Services 简介 概述 Web Services 是一种网络服务技术,允许不同的应用程序通过互联网进行交互和数据交换。随着互联网的普及和发展,Web Services 已经成为企业级应用中不可或缺的一部分。本文将详细介绍 Web Services 的概念、特点、应用场景以及相关的技术架构。 什么…...

数据仓库 - 转转 - 一面凉经

面试流程 自我介绍 Python 中,如何在数据清洗过程中应对内存不够的情况 如何避免,在使用Pandas处理大规模数据时,经常会遇到“SettingWithCopyWarning”警告 在Hive中,当您使用动态分区功能进行数据插入时,可能会遇…...

2025跳槽学习计划

(1)编程基础: 目录学习资料Chttps://www.bilibili.com/video/BV1z64y1U7hs?spm_id_from333.1387.favlist.content.clickLinuxPytorchhttps://www.bilibili.com/video/BV1if4y147hS?spm_id_from333.1387.favlist.content.clickopencv数据结…...