sql递归函数(自定义函数递归查找) 能返回递归的层次
2014-03-14 21:47
281 查看
实现效果图如下:
![](https://oscdn.geek-share.com/Uploads/Images/Content/202003/17/166540d870249f594d63e06c95f57f35.jpg)
创建表:
create table t_tree
(
id int IDENTITY(1,1),
parentid int,
name varchar(10)
)
go
插入测试数据:
insert into t_tree select 0,''
insert into t_tree select 1,''
insert into t_tree select 1,''
insert into t_tree select 2,''
insert into t_tree select 3,''
insert into t_tree select 3,''
insert into t_tree select 5,''
insert into t_tree select 5,''
insert into t_tree select 5,''
go
创建函数:
create function get_child(@id int)
returns @child table (id int,parentid int,name varchar(10),level int)
as
begin
declare @level int
set @level=0
insert into @child select *,@level from t_tree where id=@id
while @@rowcount>0
begin
set @level=@level+1
insert into @child select a.*,@level from t_tree a,@child b where b.id=a.parentid and b.level=@level-1
end
return
end
go
执行:
select * from get_child(1)
![](https://oscdn.geek-share.com/Uploads/Images/Content/202003/17/166540d870249f594d63e06c95f57f35.jpg)
创建表:
create table t_tree
(
id int IDENTITY(1,1),
parentid int,
name varchar(10)
)
go
插入测试数据:
insert into t_tree select 0,''
insert into t_tree select 1,''
insert into t_tree select 1,''
insert into t_tree select 2,''
insert into t_tree select 3,''
insert into t_tree select 3,''
insert into t_tree select 5,''
insert into t_tree select 5,''
insert into t_tree select 5,''
go
创建函数:
create function get_child(@id int)
returns @child table (id int,parentid int,name varchar(10),level int)
as
begin
declare @level int
set @level=0
insert into @child select *,@level from t_tree where id=@id
while @@rowcount>0
begin
set @level=@level+1
insert into @child select a.*,@level from t_tree a,@child b where b.id=a.parentid and b.level=@level-1
end
return
end
go
执行:
select * from get_child(1)
相关文章推荐
- 从递归版归并排序算法看递归函数连续两次调用自己函数每步如何返回,看递归和栈的关系
- 使PHP自定义函数返回多个值
- Python 函数式编程(高阶函数、把函数作为参数、map()函数、reduce()函数、filter()函数、自定义排序函数、函数返回函数、闭包、匿名函数、装饰器decorator)
- POJ1003 二分_查找/自定义zero()函数
- 利用返回指针值的函数进行查找学生的成绩
- 数据结构(六)——二叉树 前序、中序、后序、层次遍历及非递归实现 查找、统计个数、比较、求深度的递归实现
- 使用递归实现DigitSum()函数,输入一个非负整数,返回组成它的数字之和
- 编写一个函数 char *strfind(char *s, char *t),用于查找字符串t在字符串s中最右边出现的位置,如果没有找到则返回NULL.
- 使PHP自定义函数返回多个值
- 二叉树 前序、中序、后序、层次遍历及非递归实现 查找、统计个数、比较、求深度的递归实现
- 数据结构 —— 二叉树 前序、中序、后序、层次遍历及非递归实现 查找、统计个数、比较、求深度的递归实现
- [C++学习笔记14]动态创建对象(定义静态方法实现在map查找具体类名对应的创建函数,并返回函数指针,map真是一个万能类)good
- php自定义函数之递归删除文件及目录
- SQL Server返回递归结果集的函数
- 数据结构(六)——二叉树 前序、中序、后序、层次遍历及非递归实现 查找、统计个数、比较、求深度的递归实现
- 使PHP自定义函数返回多个值
- # MySQL编程基础——自定义函数返回值
- 自定义函数中返回值为指针类型的问题(2)
- Mysql中的递归层次查询(根据父节点查找所有的子节点和根据子节点查询所有的父节点)的两种运用
- 数据结构(六)——二叉树 前序、中序、后序、层次遍历及非递归实现 查找、统计个数、比较、求深度的递归实现