深入理解 SQL 中的 WITH AS 语法

在日常数据库操作中,SQL 语句的复杂性往往会影响到查询的可读性和维护性。为了解决这个问题,Oracle 提供了 WITH AS 语法,这一功能可以极大地简化复杂查询,提升代码的清晰度。本文将详细介绍 WITH AS 的基本用法、优势以及一些实际应用示例。

1. 什么是 WITH AS

WITH AS 语法又称为公共表表达式(CTE,Common Table Expression),允许开发者在一个查询中定义一个或多个临时结果集,这些结果集可以在随后的主查询中被引用。通过这种方式,开发者可以将复杂的查询逻辑分解为更易于理解和维护的多个部分。
基本语法
基本的 WITH AS 语法结构如下:

WITH CTE_name AS (SELECT column1, column2FROM table_nameWHERE condition
)
SELECT *
FROM CTE_name;

2. 使用 WITH AS 的优势

2.1 提高可读性

复杂的 SQL 查询往往涉及多个嵌套的子查询,这不仅增加了代码的长度,还使得理解查询逻辑变得困难。通过 WITH AS,我们可以将逻辑划分为多个部分,每个部分清晰地命名,便于其他开发者或未来的自己快速理解。

2.2 避免重复计算

在一些复杂查询中,同一个计算可能会被多次调用。如果我们在每个地方都写相同的子查询,既浪费了资源,又降低了代码的可维护性。使用 WITH AS 可以只计算一次,然后在后续的查询中重用这个结果集。

2.3 递归查询支持

Oracle 的 WITH AS 还支持递归查询,这对于处理层级数据(如组织结构、文件系统等)非常有用。通过递归 CTE,开发者可以轻松地获取父子关系数据。

3. 实际应用示例

示例 1:计算平均工资

假设我们有一个员工表 employees,我们想找出工资高于 10000 的员工,并计算他们的平均工资:

WITH    employeesTemp AS (SELECT * FROM employees WHERE salary > 10000
)
SELECT AVG(salary) AS highSalary FROM employeesTemp;

在这个例子中,我们首先定义了一个临时表 employeesTemp,它包含所有工资超过 10000 的员工。随后,我们利用这个临时表计算这些员工的平均工资。

示例2:计算近10天特定时间段新增数据占比全天比例

WITH total_counts AS (
SELECTtrunc(t.CREATED_TIME) AS DAY,count(1) AS total_count
FROMt_user t
WHEREt.CREATED_TIME > SYSDATE - 10
GROUP BYtrunc(t.CREATED_TIME)
),
afternoon_counts AS (
SELECTtrunc(t.CREATED_TIME) AS DAY,count(1) AS afternoon_count
FROMt_user t 
WHEREt.CREATED_TIME > SYSDATE - 10AND TO_CHAR(t.CREATED_TIME, 'HH24') BETWEEN '15' AND '17'
GROUP BYtrunc(t.CREATED_TIME)
)
SELECTt.day,t.total_count,a.afternoon_count,ROUND(a.afternoon_count / t.total_count * 100, 2) AS percentage
FROMtotal_counts t
LEFT JOINafternoon_counts a ONt.day = a.day
ORDER BYt.day;

在这个例子中,我们首先定义了临时表total_counts和afternoon_counts,其中afternoon_counts统计的是下午15~17点数据量,最后临时表total_counts和afternoon_counts关联查询,统计出近10天内15~17点数据量占比全天数据比例
在这里插入图片描述

4. 小结

WITH AS 语法在 SQL 查询中提供了一个强大的工具,可以帮助开发者构建更清晰、更高效的查询逻辑。通过提高可读性、避免重复计算和支持递归查询。在实际开发中,合理使用这一语法可以显著提升代码的质量与维护性。

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

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

相关文章

java项目之电影评论网站(springboot)

风定落花生,歌声逐流水,大家好我是风歌,混迹在java圈的辛苦码农。今天要和大家聊的是一款基于springboot的电影评论网站。项目源码以及部署相关请联系风歌,文末附上联系信息 。 项目简介: 电影评论网站的主要使用者管…

Pnetlab免登录方式

Pnetlab免登录方式 文档:https://blog.wamoyu.com/docs/pnetlab/Installation/physicalInstallation 官方:https://pnetlab.com/pages/main Username:Michealzou password:ztr940407 操作系统:Ubuntu 20.4 1.裸机方式安装pnetlab: curl …

听书项目(一)

内容来源 尚硅谷知识星球,精选项目,只记录开发中的优点功能,并不涉及侵权问题,若有侵权联系作者删除。 项目背景 随着智能手机和高速互联网的普及,人们开始寻求更便捷的方式来获取信息和娱乐。有声书的出现使得人们…

部署DNS主从服务器

一。DNS主从服务器作用: DNS作为重要的互联网基础设施服务,保证DNS域名解析服务的正常运转至关重要,只有这样才能提供稳定、快速日不间断的域名查询服务 DNS 域名解析服务中,从服务器可以从主服务器上获取指定的区域数据文件&…

Java面向对象编程进阶(四)

Java面向对象编程进阶(四) 一、equals()方法的使用二、toString()方法的使用三、复习 一、equals()方法的使用 适用性:任何引用数据都可以使用。 自定义的类在没有重写Object中equals()方法的情况下,调用的就是Object类中声明的…

Docker搭建基于Nextcloud的个人云盘/私有云盘/个人相册/家庭NAS

安装配置Docker 官方安装文档:https://docs.docker.com/engine/install/ Docker常用命令:https://blog.csdn.net/qq_43003203/article/details/139532097?spm1001.2014.3001.5502 Docker镜像仓库配置方法和国内常用镜像仓库地址: 输入&a…

k8s 二进制部署安装(三)

目录 部署Calico Calico 工作原理 部署Calico 部署CoreDNS 负载均衡部署 部署dashboard 部署Calico 安装步骤来到 CNI 网络组件 ,在(二)中我们安装了flannel,现在我们要尝试安装另一网络组件Calico calico 不使用隧道或NAT…

Spring Task—定时任务

Spring Task 是 Spring 提供的一种轻量级定时任务调度功能,内置在 Spring 框架中。与 Quartz 等重量级调度框架相比,Spring Task 使用简便,无需额外依赖,适合在简单的调度任务场景中使用。通过注解配置方式,开发者可以…

docker 安装 PostgreSQL

参考链接 https://hub.docker.com/_/postgres 安装 # 后台运行,镜像名称为 postgres # --name postgres 容器名称为 postgres # POSTGRES_PASSWORD 超级用户的密码,超级用户名默认为:postgres,可以使用 POSTGRES_USER 环境变量设…

Flink(一)

目录 架构处理有界与无界数据部署应用到任意地方运行任意规模应用利用内存性能 流应用流处理应用的基本组件流状态时间 应用场景事件驱动应用事件驱动应用的优势Flink如何支持事件驱动应用? 典型的事件驱动示例 数据分析应用流式分析应用的优势?Flink 如…

【数据结构和算法】三、动态规划原理讲解与实战演练

目录 1、什么是动态规划? 2、动态规划实战演练 2.1 力扣题之爬楼梯问题 (1)解题思路1: (2)解题思路2: (3)动态规划(DP):解题思路 (4&#x…

中天控股智慧园区项目

— 项目概况 — 项目名称:智慧园区项目 项目地点:云南省 合作单位:中天控股集团有限公司(简称“中天控股”) 汇匠源与中天控股集团有限公司(简称“中天控股”)曾在智慧园区项目展开合作&a…

前端自学资料(笔记八股)分享—CSS(4)

更多详情:爱米的前端小笔记(csdn~xitujuejin~zhiHu~Baidu~小红shu)同步更新,等你来看!都是利用下班时间整理的,整理不易,大家多多👍💛➕🤔哦!你们…

MySQL查看某个数据库里面每张表的字符集和字符排序集

字符集: 定义了MySQL中数据在硬盘上的存储方式。例如 utfmb3、utfmb4等。每个不同的字符集都拥有一个默认的字符排序集。 字符排序集: 定义了在数据库中进行字符串比较和排序的方式。 (1)比较字符串:确定两个字符串是否…

Git相关介绍

基本概念 关注(watch) 关注项目,当项目更新可以接收到通知 事物卡片(Issue) 发现代码BUG,但是目前没有成型代码,需要讨论时用 Git工作区域 工作区 添加、编辑、修改文件等动作 暂存区 …

坚持使用kimi搭建小程序2小时(04天/05天)

运用好kimi智能助手里面的存储小程序,{缺乏一个相对稳定的反馈体系,自己所挑选的稳定反馈体系就是编程!} 开源竞争: 当你无法彻底掌握一门技术的时候,就开源这门技术,培养出更多的技术依赖,让更多人完善你…

VMware虚拟机启动报错“此主机支持 Intel VT-x,但 Intel VT-x 处于禁用状态”

之前正常使用的VMware虚拟机,突然启动时报错:此主机支持 Intel VT-x,但 Intel VT-x 处于禁用状态,详细信息如下截图所示。   百度错误信息,根据参考文献1中的方案,进入BIOS设置启动VT-x。进入BIOS后&…

spyglass关于cdc检测的一处bug

最近在使用22版spyglass的cdc检测功能,发现struct_check的cdc检测实际时存在一些bug的。 构造如下电路,当qualifier和destination信号汇聚时,如果des信号完全将qualifier gate住,sg仍然会报ac_sync。当然此问题可以通过后续funct…

基础知识-因果分析-daythree-独立性检验-贝叶斯公式及应用

根据概率乘法公式有P(AB)P(B|A)P(A)变形为除法形式,则有 更一般地,假设事件的集合B1,B2,…,Bn构成样本空间的一个划分,则根据全概率公式有 将式(2.14)中的B替换为Bi,则有 再代入P(A)的全概率计算…

Openlayers高级交互(8/20):选取feature,平移feature

本示例介绍如何在vue+openlayers中使用Translate,选取feature,平移feature。选择的时候需要按住shift。Translate 功能通常是指在地图上平移某个矢量对象的位置。在 OpenLayers 中,可以通过修改矢量对象的几何位置来实现这一功能。 效果图 配置方式 1)查看基础设置:http…