Oracle WITH 子句(也称为 公共表表达式,Common Table Expression,CTE)

在 Oracle 中,WITH 子句(也称为 公共表表达式,Common Table Expression,CTE)用于定义一个临时的命名子查询,可以在后续的 SQL 语句中多次引用。它提高了复杂查询的可读性和可维护性,尤其适合需要多次使用同一子查询或递归查询的场景。

基础语法

WITH

cte_name (column1, column2, ...) AS (

SELECT ... -- 定义临时结果集

)

SELECT ... -- 主查询(可引用CTE)

常见用途

1. 简化复杂子查询

WITH sales_summary AS (

SELECT

product_id,

SUM(amount) AS total_sales

FROM sales

GROUP BY product_id

)

SELECT

p.product_name,

s.total_sales

FROM products p

JOIN sales_summary s ON p.product_id = s.product_id;

2. 递归查询(树形结构或层次数据)

WITH employee_hierarchy (employee_id, name, manager_id, level) AS (

-- 初始查询(根节点)

SELECT

employee_id,

name,

manager_id,

1 AS level

FROM employees

WHERE manager_id IS NULL

UNION ALL

-- 递归部分

SELECT

e.employee_id,

e.name,

e.manager_id,

eh.level + 1

FROM employees e

JOIN employee_hierarchy eh ON e.manager_id = eh.employee_id

)

SELECT * FROM employee_hierarchy;

3. 组合多个CTE

WITH

cte1 AS (SELECT ... FROM table1),

cte2 AS (SELECT ... FROM table2)

SELECT

cte1.col1,

cte2.col2

FROM cte1

JOIN cte2 ON cte1.id = cte2.id;

通过 WITH 子句,可以显著提升复杂查询的结构化程度,尤其在处理多层次逻辑或递归数据时非常高效。

相关推荐
数据知道4 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707534 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha4 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
Coder_Boy_4 小时前
基于SpringAI的在线考试系统-考试系统开发流程案例
java·数据库·人工智能·spring boot·后端
Gain_chance4 小时前
35-学习笔记尚硅谷数仓搭建-DWS层最近n日汇总表及历史至今汇总表建表语句
数据库·数据仓库·hive·笔记·学习
此生只爱蛋5 小时前
【Redis】主从复制
数据库·redis
马猴烧酒.5 小时前
【面试八股|JAVA多线程】JAVA多线程常考面试题详解
java·服务器·数据库
天天爱吃肉82186 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车
大巨头6 小时前
sql2008 数据库分页语句
数据库
m0_715575346 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python