SQL Server 树形表结构非循环递归查询
一、表结构创建如下:
CREATE TABLE [dbo].[Areas] ( [Id] bigint IDENTITY(1,1) NOT NULL, [Area] nvarchar(50) COLLATE Chinese_PRC_CI_AS NOT NULL, [PId] bigint NULL )
二、通过子节点查询父节点
WITH
TREE AS(
SELECT * FROM Areas
WHERE id = 6 -- 要查询的子 id
UNION ALL
SELECT Areas.* FROM Areas, TREE
WHERE TREE.PId = Areas.Id
)
SELECT Area FROM TREE
三、通过父节点查询子节点
WITH
TREE AS(
SELECT * FROM Areas
WHERE id = 7 -- 要查询的子 id
UNION ALL
SELECT Areas.* FROM Areas, TREE
WHERE TREE.Id = Areas.PId
)
SELECT Area FROM TREE
猜您可能还喜欢
评论列表
发表评论
文章分类
文章归档
- 2025年3月 (1)
- 2024年6月 (2)
- 2024年5月 (2)
- 2024年4月 (4)
- 2024年3月 (30)
- 2024年1月 (4)
- 2023年12月 (2)
- 2023年11月 (4)
- 2023年10月 (4)
- 2023年9月 (6)
- 2023年3月 (2)
- 2023年2月 (1)
- 2023年1月 (1)
- 2022年12月 (1)
- 2022年9月 (21)
- 2022年8月 (10)
- 2022年7月 (3)
- 2022年4月 (1)
- 2022年3月 (13)
- 2021年8月 (1)
- 2021年3月 (1)
- 2020年12月 (42)
- 2020年11月 (7)
- 2020年10月 (5)
- 2020年8月 (1)
- 2020年6月 (1)
- 2020年3月 (2)
- 2019年12月 (8)
- 2019年11月 (3)
- 2019年9月 (1)
- 2019年4月 (1)
- 2019年3月 (6)
- 2019年2月 (1)
- 2018年7月 (7)
阅读排行
- 1.asp.net mvc内微信pc端、H5、JsApi支付方式总结(5915)
- 2.Windows 10休眠文件更改存储位置(3992)
- 3.各大搜索网站网站收录提交入口地址(3503)
- 4.windows 10安装myeclipse 10破解补丁cracker.jar、run.bat闪退解决办法(3478)
- 5.ECharts仪表盘实例及参数使用详解(3461)
- 6.华为鸿蒙系统清除微信浏览器缓存方法(3250)
- 7.HTML5 WebSocket与C#建立Socket连接实现代码(3218)
- 8.CERT_HAS_EXPIRED错误如何解决(3019)
- 9.Js异步async、await关键字详细介绍(lambda表达式中使用async和await关键字)(2654)
- 10.HBuilder编辑器格式化代码(2425)
