SQL中的公用表表达式

公用表表达式(CTE)

相当于可以复用的子查询

  1. 普通公用表表达式

    sql 复制代码
    # 查询员工表中所有员工的部门详细信息
    WITH cte_emp
    AS
    (SELECT DISTINCT department_id FROM employees);
    
    SELECT *
    FROM departments d JOIN cte_emp e
    ON d.department_id = e.department_id;
  2. 递归公用表表达式

    sql 复制代码
    # 找出公司中所有的下下属
    # 找到第一代管理者(老大)
    WITH RECURSIVE cte
    AS
    (SELECT employee_id, last_name, manager_id, 1 AS n
    FROM employees
    WHERE employee_id = 100;
    UNION ALL
    SELECT a.employee_id, a.last_name, a.manager_id, n+1
    FROM employees AS a JOIN cte
    ON a.manager_id = cte.employee_id
    )
    
    SELECT employee_id, last_name
    FROM cte
    WHERE n >= 3;
相关推荐
誓约酱1 小时前
Linux下ext2文件系统
android·linux·c语言·数据库·c++·后端·ubuntu
橘子师兄1 小时前
mysql本地安装和pycharm链接数据库操作
数据库·mysql·pycharm
云道轩2 小时前
openGauss 创建数据库
数据库·sql·oracle
秋夜白2 小时前
【LevelDB 和 Sqlite】
数据库·sqlite
S-X-S3 小时前
SQL美化器优化
数据库·sql
Whacky-u3 小时前
Hive SQL必刷练习题:连续问题 & 间断连续
大数据·数据库·数据仓库·sql
Lang_xi_3 小时前
汇总统计数据--SQL中聚集函数的使用
数据库·mysql
全镇人的希望3 小时前
oarcle执行报错提示:SQL 错误 [1839] [22008]: ORA-01839: 指定月份的日期无效问题解决
数据库·sql
徐礼昭|商派软件市场负责人4 小时前
支持各大平台账单处理,支持复杂业财数据的精细化对账|商派OMS
大数据·数据库·人工智能·oms·财务对账