ORACLE LEVEL函数练习

Oracle LEVEL 专项练习(必练 10 题)

LEVEL 是 Oracle 树形查询专属伪列 ,表示当前递归层级,根节点 = 1,每递归一层 + 1。

先建测试表(所有练习通用)

sql

复制代码
CREATE TABLE emp (
    emp_id NUMBER PRIMARY KEY,
    name VARCHAR2(20),
    mgr_id NUMBER
);

INSERT INTO emp VALUES(1, '董事长', NULL);
INSERT INTO emp VALUES(2, '总经理', 1);
INSERT INTO emp VALUES(3, '销售总监', 2);
INSERT INTO emp VALUES(4, '华北经理', 3);
INSERT INTO emp VALUES(5, '华南经理', 3);
INSERT INTO emp VALUES(6, '北京销售', 4);
INSERT INTO emp VALUES(7, '深圳销售', 5);

COMMIT;

练习 1:最基础 ------ 显示每个人的层级

sql

复制代码
SELECT
    emp_id,
    name,
    mgr_id,
    LEVEL 层级
FROM emp
START WITH mgr_id IS NULL
CONNECT BY PRIOR emp_id = mgr_id;

目标:理解 LEVEL 从 1 开始递增。


练习 2:只查第 2 层(总经理)

sql

复制代码
SELECT *
FROM (
    SELECT name, LEVEL 层级
    FROM emp
    START WITH mgr_id IS NULL
    CONNECT BY PRIOR emp_id = mgr_id
)
WHERE 层级 = 2;

练习 3:只查叶子节点(最底层员工)

sql

复制代码
SELECT name, LEVEL 层级
FROM emp
WHERE CONNECT_BY_ISLEAF = 1  -- 1=叶子节点
START WITH mgr_id IS NULL
CONNECT BY PRIOR emp_id = mgr_id;

练习 4:只查3 级及以下

sql

复制代码
SELECT name, LEVEL 层级
FROM emp
WHERE LEVEL <= 3
START WITH mgr_id IS NULL
CONNECT BY PRIOR emp_id = mgr_id;

练习 5:按层级缩进显示(树形排版)

sql

复制代码
SELECT
    LPAD(' ', 2*(LEVEL-1)) || name AS 树形结构,
    LEVEL 层级
FROM emp
START WITH mgr_id IS NULL
CONNECT BY PRIOR emp_id = mgr_id;

练习 6:向上递归查上级,LEVEL 反向计数

sql

复制代码
-- 查"北京销售"所有上级,LEVEL 从自己开始=1
SELECT name, LEVEL
FROM emp
START WITH name = '北京销售'
CONNECT BY PRIOR mgr_id = emp_id;

练习 7:用 LEVEL 生成连续数字(面试高频)

不用表,直接生成 1~10:

sql

复制代码
SELECT LEVEL AS num
FROM dual
CONNECT BY LEVEL <= 10;

生成 5~15:

sql

复制代码
SELECT LEVEL+4 AS num
FROM dual
CONNECT BY LEVEL <= 11;

练习 8:生成连续日期(LEVEL 超级常用)

生成未来 7 天:

sql

复制代码
SELECT
    SYSDATE + LEVEL - 1 AS dt,
    LEVEL
FROM dual
CONNECT BY LEVEL <= 7;

练习 9:生成多行重复数据(测试数据专用)

sql

复制代码
SELECT '测试数据' || LEVEL AS txt, LEVEL
FROM dual
CONNECT BY LEVEL <= 5;

练习 10:限定递归深度(最多递归 2 层)

sql

复制代码
SELECT name, LEVEL
FROM emp
START WITH mgr_id IS NULL
CONNECT BY PRIOR emp_id = mgr_id
       AND LEVEL <= 2; -- 只到总经理

LEVEL 核心口诀

  1. 根节点 LEVEL=1
  2. 向下递归:PRIOR 子ID = 父ID
  3. 向上递归:PRIOR 父ID = 子ID
  4. 生成序列 / 日期:CONNECT BY LEVEL <= N
  5. 过滤层级:WHERE LEVEL = xLEVEL <= x
相关推荐
杜子不疼.5 分钟前
用 JiuwenSwarm 搭建 SRE 智能值班体系:告警分级、根因分析与应急手册生成
数据库
接着奏乐接着舞12 分钟前
java 数据结构
数据库·redis·缓存
时空自由民.12 分钟前
PID介绍
数据库·mongodb
m0_6091604914 分钟前
如何用 some 检测数组中是否存在至少一个满足条件的项
jvm·数据库·python
|_⊙17 分钟前
Linux 深入理解文件(Ext2文件系统:上)
linux·运维·数据库
情绪总是阴雨天~21 分钟前
大模型 Function Call(函数调用)详解:原理、实践与数据库智能查询 Agent
前端·数据库·人工智能
m0_702036531 小时前
如何从Oracle Java调用外部API_HTTP请求在数据库Java Source中的实现
jvm·数据库·python
六月雨滴1 小时前
数据库权限管理(Privilege Management)
数据库·oracle·dba
aisifang001 小时前
企业级GPT-Image2实战测评:从生成到生产
大数据·数据库·人工智能
TO_WebNow1 小时前
MySQL 索引的相关知识
数据库·mysql