zoukankan      html  css  js  c++  java
  • MSSQLSERVER数据库 递归查询例子

    SqlServer2005版本的Sql如下:
    比如一个表,有id和pId字段,id是主键,pid表示它的上级节点,表结构和数据:
    CREATE TABLE [aaa](
     [id] [int] NULL,
     [pid] [int] NULL,
     [name] [nchar](10)
    )
    GO
    INSERT INTO aaa VALUES(1,0,'a')
    INSERT INTO aaa VALUES(2,0,'b')
    INSERT INTO aaa VALUES(3,1,'c')
    INSERT INTO aaa VALUES(4,1,'d')
    INSERT INTO aaa VALUES(5,2,'e')
    INSERT INTO aaa VALUES(6,3,'f')
    INSERT INTO aaa VALUES(7,3,'g')
    INSERT INTO aaa VALUES(8,4,'h')
    GO

    --下面的Sql是查询出1结点的所有子结点
    with my1 as(select * from aaa where id = 1
     union all select aaa.* from my1, aaa where my1.id = aaa.pid
    )
    select * from my1

    --结果包含1这条记录,如果不想包含,可以在最后加上:where id <> 1
    --自己的理解:首先查找出根结点
    --自己的理解:接着进行联合,查找出根结点下面的所有子结点
    --自己的理解:接着还是进行联合,查找出最后一个结点下面所有的子结点,再查找出最后一个结点的上一个结点的所有子结点,以此类推下去。
    --自己的理解:假设虚拟出my1的表, 我们不停的将查询的结果 往my1的表里装
    --自己的理解:当运行到UNION ALL后面的select表后就一直在with my和UNION ALL这两句之间进行来回切换,不会再运行select * from aaa where id = 1这句


    --下面的Sql是查询出8结点的所有父结点
    with my1 as(select * from aaa where id = 8
     union all select aaa.* from my1, aaa where my1.pid = aaa.id
    )
    select * from my1;

    --下面是递归删除1结点和所有子结点的语句:
    with my1 as(select * from aaa where id = 1
       union all select aaa.* from my1, aaa where my1.id = aaa.pid
    )
    delete from aaa where exists (select id from my1 where my1.id = aaa.id)

    原文网址包括了ORALCE的递归查询例子:http://blog.csdn.net/pdn2000/article/details/6674243

  • 相关阅读:
    kubernetes 二进制安装v2
    Istio
    linux的history指令显示时间
    echarts折线图y轴刻度值按照某个值的倍数
    ubuntu下tesseract 4.0安装及参数使用
    chrome 浏览器下载大文件断掉的问题
    强化学习
    第十一篇 -- 2020总结以及2021期待
    字符串时间yyyyMMddHHmmss转成yyyy-MM-dd HH-mm-ss字符串格式
    windows安装mongodb,密码访问
  • 原文地址:https://www.cnblogs.com/cxeye/p/2909155.html
Copyright © 2011-2022 走看看