怎么新建MySQL数据库

发布时间:2022-07-04 作者:admin
阅读:558
今天这篇给大家分享的知识是“SQL Server中怎样进行树形查询,SQL语句是什么”,小编觉得挺不错的,对大家学习或是工作可能会有所帮助,对此分享发大家做个参考,希望这篇“SQL Server中怎样进行树形查询,SQL语句是什么”文章能帮助大家解决问题。




很多人可能想要查询整个树形表关联的内容都会通过循环递归来查...事实上在微软在SQL2005或以上版本就能用别的语法进行查询,下面是示例。

--通过子节点查询父节点
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

通过子节点查询父节点查询结果为:

修改代码为

--通过子节点查询父节点
declare @area varchar(8000);
WITH 
TREE AS( 
SELECT * FROM Areas 
WHERE id = 6 -- 要查询的子 id 
UNION ALL 
SELECT Areas.* FROM Areas, TREE 
WHERE TREE.PId = Areas.Id
)
select @area=isnull(@area,'')+Area from Tree order by id 
select Area= @area

则结果为:中国北京市丰台区

根据以上可以将这段代码封装为一个存储过程

-----存储过程,递归获取树形地区表字符串
if exists (select * from sysobjects where name='SP_GetAreaStr')
drop proc SP_GetAreaStr
go
create procedure SP_GetAreaStr 
@id int
as
declare @area varchar(8000)
begin
WITH 
TREE AS( 
SELECT * FROM Areas 
WHERE id = @id -- 要查询的子 id 
UNION ALL 
SELECT Areas.* FROM Areas, TREE 
WHERE TREE.PId = Areas.Id
)
select @area=isnull(@area,'')+Area from Tree order by id 
select Area= @area
end 
go
--exec sp_helptext 'SP_GetAreaStr'
--go
exec SP_GetAreaStr 28
go

查询结果:中国安徽省宿州市灵璧县

所用表结构:

部分数据:


到此这篇关于“SQL Server中怎样进行树形查询,SQL语句是什么”的文章就介绍到这了,更多相关内容请搜索群英网络以前的文章或继续浏览下面的相关文章,希望大家以后多多支持群英网络!

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。

二维码-群英

长按识别二维码并关注微信

更方便到期提醒、手机管理

7*24 全天候服务

售前 400-678-4567

售后 0668-2555666

售后 400 678 4567

信息安全 0668-2555 118

域名空间 3004329145