SQL查询某一指定用户的所有下级用(即所有的子孙曾孙等等)
表字段,以及数据结构如下:
用户ID | 用户名称 | 父用户ID | 父用户名称
userid | username | parentUserId | parentUserName
1 | admin | 0 | NULL
2 | aaaaa | 1 | admin
3 | bbbbb | 2 | aaaaa
4 | ddddd | 3 | bbbbb
以此类推。。。
用户SQL查询某一指定用户的所有下级用(即所有的子孙曾孙等等),例如:
查询 userid 为 1 的管理员下级所有子孙用户
SELECT * FROM [DBO].fn_GetUserChildTest(1)
在线等,不胜感谢。。。
==================================================
本来一直用下面的 SQL 查询,但发现深层下级曾孙之后的无法查到,如下:
CREATE FUNCTION fn_GetUserChildTest(@userid INT) RETURNS @t TABLE(
userid INT,
username nvarchar(20),
ParentUserID INT,
parentUserName nvarchar(20),
Level INT
) AS
BEGIN
DECLARE @i INT
SET @i = 1
INSERT INTO @t SELECT userid, username, ParentUserID, parentUserName, @i FROM [Users] WHERE ParentUserID = @userid
WHILE @@ROWCOUNT <> 0
BEGIN
SET @i = @i + 1
INSERT INTO @t SELECT a.userid, a.username, a.ParentUserID, a.parentUserName, @i FROM [Users] a, @t b
WHERE a.ParentUserID = b.userid AND b.Level = @i - 1
END
RETURN
END
GO SQL select 查询所有下级用户
[解决办法]
如果sql2005,使用 with 递归
[解决办法]
以当前的数据测试没有问题
[解决办法]
本帖最后由 htl258 于 2013-07-28 10:03:59 编辑 --发个SQL2005以上可使用的。
--> 生成测试数据表: [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 t 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 t where [parentUserId]<>0
/*
userid username parentUserId parentUserName level
----------- ---------- ------------ -------------- -----------
2 aaaaa 1 admin 2
3 bbbbb 2 aaaaa 3
4 ddddd 3 bbbbb 4
(3 行受影响)
*/