在SQL的树型结构中,很多时候,知道某一节点的值,需要查找该节点的所有子节点(包括多级)的功能,这时就需要用到如下的用户自定义函数.

表结构如下:

ID int
Dep_Type int
Dep_Code varchar(50)
Dep_Name varchar(50)
Dep_Dian int
Dep_FathID int
Dep_Opera varchar(50)
Dep_Status int
Dep_AddTime datetime

用户自定义函数如下:

create function f_getChild(@ID VARCHAR(10)) 
returns @t table(ID VARCHAR(10),PID VARCHAR(10),Level INT) 
as 
begin 
    declare @i int,@ret varchar(8000) 
    set @i = 1 
    insert into @t select ID,Dep_FathID,@i from H_Dep_Info where Dep_FathID = @ID 
    while @@rowcount<>0 
    begin 
      set @i = @i + 1 
      insert into @t select a.ID,a.Dep_FathID,@i from H_Dep_Info a,@t b where a.Dep_FathID=b.ID and b.Level = @i-1 
    end 
    return 
end

执行操作如下:

select ID from f_getChild(1)

返回值就是所有的子节点

查找父节点的函数如下:

CREATE FUNCTION [f_getParent](@id int) 
  RETURNS @re TABLE(id int,pid int,level int) 
  AS 
  begin 
  declare @level int 
  set @level = 1 
  declare @pid int 
  select @pid = pid from tb where id = @id 
  insert @re 
  select id,pid,@level from tb where id = @pid 
  while @@rowcount > 0   
  begin 
  set @level = @level + 1 
  select @pid = pid from tb where id = @pid 
  insert @re 
  select id,pid,@level from tb where id = @pid 
  end 
  return 
  end

执行操作如下:

select * from f_getParent(8)

返回的列有id,pid,level

其中id就是8的父节点,pid就是id的父节点,level就是级数(表示这个id是8的第几级你节点)

SQL 递归找查所有子节点及所有父节的更多相关文章

  1. sql 递归查询,查出所有子节点

    with t as ( select b.* from Base_Department b where ParentId = 'cce4152c-3483-4334-b68d-155da627bca0 ...

  2. 递归遍历所有xml的节点及子节点

    import java.io.File; import java.util.List; import org.dom4j.Attribute; import org.dom4j.Document; i ...

  3. [SQL]T-Sql 递归查询(给定节点查所有父节点、所有子节点的方法)

    T-Sql 递归查询(给定节点查所有父节点.所有子节点的方法)   -- 查找所有父节点with tab as( select Type_Id,ParentId,Type_Name from Sys_ ...

  4. mysql 递归查找菜单节点的所有子节点

    背景                                                                                                   ...

  5. SQL查询树形结构的所有子节点

    如下一张表test:id name pid----------- ---------- -----------1 电器 NULL2 家电 13 冰箱 24 洗衣机 25 电脑 16 笔记本 57 平板 ...

  6. SQL SERVER 2000 遍历父子关系数据的表(二叉树)获得所有子节点 所有父节点及节点层数函数

    ---SQL SERVER 2000 遍历父子关系數據表(二叉树)获得所有子节点 所有父节点及节点层数函数---Geovin Du 涂聚文--建立測試環境Create Table GeovinDu([ ...

  7. dom4j递归解析XML字符串所有子节点

    /** * dom4j递归解析所有子节点 * * @param childElements * @param mapEle * @return */ public Map<String, Obj ...

  8. T-Sql 递归查询(给定节点查所有父节点、所有子节点的方法)

    -- 查找所有父节点with tab as( select Type_Id,ParentId,Type_Name from Sys_ParamType_V2_0 where Type_Id=316-- ...

  9. SQL 递归树 子父节点相互查询

    if object_id('[tb]') is not null drop table [tb] go create table [tb]([modeid] int,modename varchar( ...

随机推荐

  1. 【eclipse】删除工作空间

  2. codeforces 251 div2 C. Devu and Partitioning of the Array 模拟

    C. Devu and Partitioning of the Array time limit per test 1 second memory limit per test 256 megabyt ...

  3. python 生成元组

    #create a tuple l = [(,), (,), (,)] print(list(zip(*l)))

  4. 使用rviz 查看远程主机

    一.安装好ros环境 https://www.cnblogs.com/sea-stream/p/9809590.html 二.配置参数 vim ~/.bashrc #输入内容 export ROS_H ...

  5. Jenkins 构建 coding项目,插件

    安装插件:http://updates.jenkins-ci.org/download/plugins/coding-webhook/

  6. socket编程之accept()函数【转载】

    名称 accept() 接收一个套接字中已建立的连接 使用格式 #include <sys/types.h> #include <sys/socket.h> int accep ...

  7. mysql 超大数据/表管理技巧

    如果你对长篇大论没有兴趣,也可以直接看看结果,或许你对结果感兴趣.在实际应用中经过存储.优化可以做到在超过9千万数据中的查询响应速度控制在1到20毫秒.看上去是个不错的成绩,不过优化这条路没有终点,当 ...

  8. Android提高第九篇之GridView和SQLite实现分页表格

    实现并封装一个SQL分页表格控件,不仅支持分页还是以表格的形式展示数据.先来看看本文程序运行的动画: 这个SQL分页表格控件主要分为“表格区”和“分页栏”这两部分,这两部分都是基于GridView实现 ...

  9. 常用的vi/vim基本命令(持续更新)

    ★删除/复制/粘贴 全部删除:按esc后,然后dG  全部复制:按esc后,然后ggyG  全选高亮显示:按esc后,然后ggvG或者ggVG   按“+p“可将系统全局粘贴板里的内容粘贴进来   y ...

  10. 模块commonjs AMD UMD

    commonjs是用在服务器端的,同步的,如nodejs amd, cmd是用在浏览器端的,异步的,如requirejs和seajs 其中,amd先提出,cmd是根据commonjs和amd基础上提出 ...