Oracle递归查询

描述:现有两个数据表base_menu1和base_menu2,存储菜单,其中id字段表示菜单的唯一id,parent_id存储该菜单父级菜单的id,用递归查询的方式将菜单按照层级关系查询出来,并且要展示菜单的层级关系。(如区分菜单是几级菜单)

cs 复制代码
select t.id,t.name,t.parent_id
    case
        when level=1 then '一级菜单'
        when level=2 then '二级菜单'
        else '三级菜单'
    end as menu_level
 from (
     select id,name,parent_id
     from base_menu1
     union all
     select id,name,parent_id
     from base_menu2 
)t
start with t.parent_id is null
connect by prior t.id=t.parent_id

注:

  1. union all:表示两个表的查询结果合并

  2. connect by prior和start with用来实现递归查询。start with指定递归的起始节点,connect by prior指定父子关系。

  3. case when根据菜单的层级关系(level)向菜单添加level字段,使用该字段区分菜单的层级。

相关推荐
岁岁种桃花儿4 小时前
MySQL从入门到精通系列:InnoDB记录存储结构
数据库·mysql
蜜獾云5 小时前
oracle查询所有的表名和注释
oracle
jiunian_cn5 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
冉冰学姐5 小时前
SSM在线影评网站平台82ap4(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·ssm框架·在线影评平台·影片分类
知识分享小能手7 小时前
SQL Server 2019入门学习教程,从入门到精通,SQL Server 2019数据库的操作(2)
数据库·学习·sqlserver
爬山算法7 小时前
Hibernate(84)如何在DevOps流程中使用Hibernate?
oracle·hibernate·devops
踩坑小念7 小时前
秒杀场景下如何处理redis扣除状态不一致问题
数据库·redis·分布式·缓存·秒杀
萧曵 丶8 小时前
MySQL 语句书写顺序与执行顺序对比速记表
数据库·mysql
Wiktok9 小时前
MySQL的常用数据类型
数据库·mysql
曹牧9 小时前
Oracle 表闪回(Flashback Table)
数据库·oracle