加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 使用树顺序从表中选择行

发布时间:2020-12-12 06:50:11 所属栏目:MsSql教程 来源:网络整理
导读:我有表女巫包含字段:id,parent_id,name(等) 我想在“树旅行顺序”中订购此表,即. id parent_id1,03,15,12,08,24,09,4 (……) 总之描述:取根节点,追加所有子节点,取下一个根节点追加子节点等. 解决方法 根据您的描述,我假设您的意思是广度优先顺序,可以使用W
我有表女巫包含字段:id,parent_id,name(等)

我想在“树旅行顺序”中订购此表,即.

id  parent_id
1,0
3,1
5,1

2,0
8,2

4,0
9,4

(……)

总之描述:取根节点,追加所有子节点,取下一个根节点追加子节点等.

解决方法

根据您的描述,我假设您的意思是广度优先顺序,可以使用WITH RECURSIVE查询(PostgreSQL 8.4)轻松完成:
WITH RECURSIVE tree 
AS 
(
    SELECT 
        node_name,id,NULL::varchar AS parent_name 
    FROM foo 
    WHERE parent_id IS NULL 
    UNION
    SELECT 
        node_name,f1.id,f1.parent_id,tree.node_name AS parent_name 
    FROM 
        tree 
        JOIN foo f1 ON f1.parent_id = tree.id
) 
SELECT node_name,empno,node_name FROM tree;

您还可以使用以下SQL使用深度优先顺序:

WITH RECURSIVE tree 
AS 
(
    SELECT 
        node_name,NULL::varchar AS parent_name,id::text AS path 
    FROM foo WHERE parent_id IS NULL 
    UNION
    SELECT 
        node_name,tree.node_name AS parent_name,tree.path || '-' || f1.id::text AS path 
    FROM 
        tree 
        JOIN foo f1 ON f1.parent_id = tree.id
) 
SELECT node_name,node_name,path FROM tree ORDER BY path;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读