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

  • 相关阅读:
    ASP.NET MVC 页面重定向
    Linux用户管理
    linux开机、重启和用户注销
    vi和vim
    Mac 与 Linux服务器上传下载
    linux 文件体系
    linux 常用命令及异常处理
    单独使用ueditor的图片上传功能,同时获得上传图片地址和缩略图
    mybatis oracle 插入自增记录 获取主键值 写回map参数
    MyBatis SpringMVC映射配置注意
  • 原文地址:https://www.cnblogs.com/cxeye/p/2909155.html
Copyright © 2011-2022 走看看