码迷,mamicode.com
首页 > 数据库 > 详细

sql 递归查询所有的下级

时间:2017-06-24 18:44:46      阅读:318      评论:0      收藏:0      [点我收藏+]

标签:color   查询   null   ring   object_id   ber   where   number   影响   

--> 生成测试数据表: [tb]

IF OBJECT_ID(‘[Users]‘IS NOT NULL
    DROP TABLE [Users]
GO
CREATE TABLE [Users] ([userid] [int],[username] [nvarchar](10),[parentUserId] [int],[parentUserName] [nvarchar](10))
INSERT INTO [Users]
SELECT ‘1‘,‘admin‘,‘0‘,NULL UNION ALL
SELECT ‘2‘,‘aaaaa‘,‘1‘,‘admin‘ UNION ALL
SELECT ‘3‘,‘bbbbb‘,‘2‘,‘aaaaa‘ UNION ALL
SELECT ‘4‘,‘ddddd‘,‘3‘,‘bbbbb‘
-->SQL查询如下:
;with as
(
  select *,level=1 from Users where [parentUserId]=0
  union all
  select a.*,level+1 from Users a join t b on a.parentUserId=b.userid
)
select from where [parentUserId]<>0
/*
userid      username   parentUserId parentUserName level
----------- ---------- ------------ -------------- -----------
2           aaaaa      1            admin          2
3           bbbbb      2            aaaaa          3
4           ddddd      3            bbbbb          4
  
(3 行受影响)
*/

sql 递归查询所有的下级

标签:color   查询   null   ring   object_id   ber   where   number   影响   

原文地址:http://www.cnblogs.com/soundcode/p/7073916.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!