在项目应用中,有些表的数据呈现出树型结构,比如部门表,菜单表,如果我们按照常规的方法查询出来,可能不太直观,这时需要借助LPAD函数以及LEVEL伪列来分层查询
select v.id, LPAD(' ', 2 * LEVEL - 1, ' ') || v.parentName as dept_name
from sys_dept_v v
connect by prior v.id = v.parent_dept_id
start with 子句:遍历起始条件,有个小技巧,如果要查父结点,这里可以用子结点的列,反之亦然。
connect by 子句:连接条件。关键词prior,prior跟父节点列parentid放在一起,就是往父结点方向遍历;prior跟子结点列subid放在一起,则往叶子结点方向遍历
parentid、subid两列谁放在“=”前都无所谓,关键是prior跟谁在一起。