Oracle层次查询和with函数的使用
开发中大家应该都做过什么类似部门管理这样的功能,一般情况下一个部门下面还有下一级部门(子部门),这个层级就类似一棵树。这种情况下一般会把父级部门和子级部门分成2个或者多个表,这种算是比较常规的做法;有时可能为了数据表管理的方便 就把所有的部门放在一张表里并加上一个字段标识部门之间的隶属关系,这样子看起来有点奇怪,但凑合用用还是Ok的。下面我跟大家分享下我的心得,也就是基于这种设计怎么做数形图,简单的做法就是查询出一个list集合就可以,要怎么办呢先来看下我的数据表
不难看出部门之间用fparent关联,那sql语句怎么写呢,下面是一种偷懒的写法
-- ||是连接符,level可以看成常量 select t.fnum,LPAD(' ',3*level-3)||'|-'||fname fname,t.fparent,Level lev From m_depart t --start with后面是条件1 start with fparent is null --connect by Prior后面是条件2 connect by Prior fnum=fparent
下面是查询结果,查询结果和数非常接近
差不多了下面还有一个比较常用的with函数,一般做复杂查询可能会用到,可以参考下面的文章
http://www.cnblogs.com/booolee/archive/2009/09/15/1566827.html
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步