首页 > 数据库技术 > 详细

SQL 递归

时间:2015-03-20 10:30:53      阅读:334      评论:0      收藏:0      [点我收藏+]

题目:

生活中,常遇到ID和ParentID引用问题。

比如当前文件夹下的所有文件夹。

 

分析:

核心思想递归当前文件下的子文件夹。

 

脚本:

 

技术分享
CREATE TABLE Dept(
    [id] int NULL,
    [parentid] int NULL,
    [name] nvarchar(50) NULL,
    [type] int NULL
)
创建表

 Type:0-文件夹;1-文件

 

技术分享插入
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(1,0,dept1,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(2,0,dept2,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(3,1,dept3.1,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(4,1,dept4.1,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(5,2,dept5.2,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(6,3,dept6.3,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(7,3,dept7.3,1);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(8,1,dept8.1,0);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(9,3,dept9.3,0);
INSERT INTO [dbo].[Dept]([id],[parentid],[name],[type])VALUES(10,1,dept10.1,0);
数据

 

技术分享
declare @deptid int
set @deptid=3;

with depts as
(
select * from Dept where id =@deptid
union all
select A.* 
from Dept A inner join depts B
on A.parentid=b.id --and a.[type]=1
)
select * from depts order by parentid, id, type
查询脚本

 

SQL 递归

原文:http://www.cnblogs.com/xuqihe/p/4352859.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!