在SQL中使用递归查询具有树型结构的的数据表

在SQLSERVER2005中有一个关键字"with",使用这个关键字可以轻松的实现对于一张数据表(本身必须具有树型结构)的查询,并且将结构树型化。

    with bbb as
(
SELECT channels.name,channels.id,channels.parentid,depth=0,px=CAST(id AS VARBINARY) from channels WHERE ISNULL(parentid,0)=0
union all
select channels.name,channels.id,channels.parentid,depth=depth+1,CAST(px+CAST(channels.id AS VARBINARY) AS VARBINARY)
from channels ,bbb
where channels.parentid=bbb.id
)
select * from bbb order by px

如上图,其中channels是需要查询的数据表,新增加的字段depth表示的是递归深度,px则是用于树型排序的序列号,查询的结果如下

如上图所示,可以轻松完成一个树型查询(即使是无限级分类)

 

posted on 2011-09-25 15:58  Tim Feng  阅读(534)  评论(2编辑  收藏  举报

导航