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
相关推荐
不会就选b13 小时前
MySQL之视图
数据库·mysql
>no problem<13 小时前
基于cola5.0的基础设施层的多数据库切换方案思路
数据库·spring boot·mybatisplus·cola5.0·数据库迁移适配
OceanBase数据库官方博客13 小时前
OceanBase 赋能央国企:从发电到用电的全链路业务承载
数据库·oceanbase
瀚高PG实验室14 小时前
pgsql-ogr-fdw
数据库·postgresql·瀚高数据库·highgo
IvorySQL14 小时前
PostgreSQL 技术日报 (6月5日)|PG19 Beta1 上线,PGConf.PL 2026开启征稿
数据库·postgresql·区块链
abcy07121315 小时前
pycharm python sqlalchemy mysql增删改查实例csdn
数据库·oracle
无风听海15 小时前
IndexedDB 深度指南 浏览器中的事务型对象数据库
前端·数据库
咋吃都不胖lyh16 小时前
langgraph基础示例
数据库
网管NO.116 小时前
子查询进阶|EXISTS/IN/ANY/ALL,优化查询效率
数据库·sql
云服务器租用费用17 小时前
2026年腾讯云OpenClaw(Clawdbot)+Skills云上部署及Windows本地集成轻松入门
运维·服务器·数据库·windows·云计算·腾讯云