视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
不用CTE实现树形结构查询
2020-11-09 07:33:45 责编:小采
文档


--建测试表IF OBJECT_ID('wx_test_dep') IS NOT NULLDROP TABLE wx_test_depGOCREATE TABLE wx_test_dep(depId INT PRIMARY KEY,pDepId INT,depName NVARCHAR(20))GO--插入测试数据INSERT INTO wx_test_dep VALUES (1,0,'武汉大学')INSERT INTO wx_test_dep

--建测试表
IF OBJECT_ID('wx_test_dep') IS NOT NULL
	DROP TABLE wx_test_dep
GO
CREATE TABLE wx_test_dep(
	depId INT PRIMARY KEY,
	pDepId INT,
	depName NVARCHAR(20)
)
GO
--插入测试数据
INSERT INTO wx_test_dep VALUES (1,0,'武汉大学')
INSERT INTO wx_test_dep VALUES (2,0,'华科大')
INSERT INTO wx_test_dep VALUES (3,1,'武大后勤部')
INSERT INTO wx_test_dep VALUES (4,3,'武大后勤部技术科')
INSERT INTO wx_test_dep VALUES (5,3,'武大后勤部供应科')
INSERT INTO wx_test_dep VALUES (6,2,'华科大学生部')
INSERT INTO wx_test_dep VALUES (7,6,'华科大学生部技术科')
INSERT INTO wx_test_dep VALUES (8,6,'华科大学生部教务科')
-- 武汉大学
-- --武大后勤部
-- ----武大后勤部技术科
-- ----武大后勤部供应科
-- 华科大
-- --华科大学生部
-- ----华科大学生部技术科
-- ----华科大学生部教务科
--SELECT * FROM wx_test_dep wtd

--查出华科大所有子部门
/*
2	0	华科大
6	2	华科大学生部
7	6	华科大学生部技术科
8	6	华科大学生部教务科 
* */

DECLARE @t TABLE (
	depId INT,
	pDepId INT,
	depName NVARCHAR(20)
)

INSERT INTO @t
SELECT * FROM wx_test_dep wtd WHERE wtd.depId=2

WHILE EXISTS(
	SELECT 1 FROM wx_test_dep w WHERE EXISTS(
	SELECT 1 FROM @t t WHERE w.pDepId=t.depId-- AND w.depId!=t.depId
	)
	AND NOT EXISTS (
	SELECT 1 FROM @t t WHERE w.depId=t.depId
	)
)
BEGIN
	INSERT INTO @t
	SELECT
	wtd.depId,
	wtd.pDepId,
	wtd.depName
	FROM
	wx_test_dep wtd WHERE EXISTS(
	SELECT 1 FROM @t t WHERE wtd.pDepId=t.depId-- AND wtd.depId!=t.depId 	
	)
	AND NOT EXISTS (
	SELECT 1 FROM @t t WHERE wtd.depId=t.depId
	)
END

SELECT * FROM @t

下载本文
显示全文
专题