oracle中有connect by prior ,可以实现父子递归查询。而mysql中没有这种功能,但我们可以变通实现。

 比如一个表:

Table Name: tb_Tree

Id | ParentId | Name
--------------------
1  | 0        | Fruits
2  | 0        | Vegetables
3  | 1        | Apple
4  | 1        | Orange
5  | 2        | Cabbage
6  | 2        | Eggplant

我们需要知道某个ID的所有下级。

以下这个查询,可以列出所有水果蔬菜的四层上级ID,如果没有四级,则相应的parentid为Null。(你也可以扩展级数)

select id,name,parentid 
,(select parentid from tb_tree where id=t.parentid) parentid2 
,(select parentid from tb_tree where id=(select parentid from tb_tree where id=t.parentid)) parentid3 
,(select parentid from tb_tree where id=(select parentid from tb_tree where id=(select parentid from tb_tree where id=t.parentid))) parentid4 
from tb_tree t 

于是我们很方便查到我们所要的结果,比如要查fruits的所有children:
select id ,name from (
        select id, name, parentid
        ,(select parentid from tb_tree where id=t.parentid) parentid2
        ,(select parentid from tb_tree where id=(select parentid from tb_tree where id=t.parentid)) parentid3
        ,(select parentid from tb_tree where id=(select parentid from tb_tree where id=(select parentid from tb_tree where id=t.parentid))) parentid4 
        from tb_tree t) tt
    where ifnull(parentid4,0)=1 or ifnull(parentid3,0)=1 or ifnull(parentid2,0)=1 or ifnull(parentid,0)=1

 


 
                    
            
                

相关文章:

  • 2021-10-07
  • 2021-11-23
  • 2021-10-17
  • 2022-12-23
  • 2022-12-23
  • 2021-11-30
  • 2021-07-15
  • 2021-05-01
猜你喜欢
  • 2021-09-21
  • 2021-11-01
  • 2021-11-27
  • 2021-10-17
  • 2022-12-23
  • 2022-12-23
  • 2021-06-27
相关资源
相似解决方案