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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

愿与狸花过一生

盛时常作衰时想 上场当念下场时

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值