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

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

 

相关文章:

  • 终止进程kill和killall
  • 智能合约开发中13种最常见的漏洞
  • 队列的各种操作实现(数据结构C语言多文件编写)
  • 从零构建大模型之Transformer公式解读
  • 大联盟(特别版)双端互动平台完整套件分享:含多模块源码+本地部署环境
  • QT Sqlite数据库-教程002 查询数据-上
  • Java集合框架深度解析:核心接口、实现类与应用场景
  • Android基础入门、Android常见界面布局基础练习
  • 回溯-day65
  • Neovim安装及lazy配置
  • ADI的BF561双核DSP怎么做开发,我来说一说(十六)触摸屏的设计
  • QT Sqlite数据库-教程002 查询数据-下
  • 操作系统导论——第19章 分页:快速地址转换(TLB)
  • Vue.js 项目中 vue.config.js 常用配置项解析
  • bash的特性-命令和文件自动补全
  • Linux - 系统服务管理(Systemd)
  • qt中的正则表达式
  • 【记录】Docker 镜像
  • Java-面向对象
  • ffprobe是如何处理命令行参数的.
  • 建行原副行长章更生被开除党籍:靠贷吃贷,大搞权钱交易
  • 当代读书人的暗号:不是拆快递,是拆出版社样书!|世界读书日特辑
  • “从山顶到海洋”科技成果科普巡展在重庆启动,免费开放
  • 福建浯屿岛垃圾排海追踪:堆存已清理,当地称今后会日产日清日运
  • 著名电化学家、我国工业电化学奠基人之一郭鹤桐逝世
  • 女子拿蘸料时触电受伤,海底捞回应