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 子句,可以显著提升复杂查询的结构化程度,尤其在处理多层次逻辑或递归数据时非常高效。

相关推荐
cyber_两只龙宝10 分钟前
【Oracle】Oracle之DQL中SELECT的基础使用
linux·运维·服务器·数据库·云原生·oracle
老苏畅谈运维10 分钟前
Oracle 在线表重定义:将非分区表转换为分区表的最佳实践
数据库·oracle
treacle田15 分钟前
达梦数据库-达梦数据库中link链接访问oracle 19c/11g-记录总结
数据库·oracle·达梦 link访问oracle
萌兰三太子17 分钟前
RAG 向量数据库设计指南:从入门到生产
数据库·oracle
TDengine (老段)33 分钟前
中原油田引入时序数据库 TDengine:写入性能提升、存储成本下降 85%
大数据·数据库·人工智能·时序数据库·tdengine·涛思数据
IT邦德37 分钟前
Oracle 26ai搭建ADG Far Sync日志备库
数据库·oracle
Crazy CodeCrafter1 小时前
现在做服装,实体和电商怎么选?
大数据·数据库·人工智能·微信·开源软件·零售
一江寒逸1 小时前
零基础从入门到精通MongoDB(下篇):进阶精通篇——吃透高级查询、事务、索引优化与集群架构,成为MongoDB实战高手
数据库·mongodb·架构
sa100271 小时前
一键获取淘宝天猫商品评论:API 接口实战与多语言实现教程
数据库·oracle
huanmieyaoseng10031 小时前
Linux安装达梦数据库DM8
linux·运维·数据库