日期:2014-05-17 浏览次数:20743 次
; with cte as ( select * from tb where type_id=1 union all seelct b.* from cte as c,tb as b where c.peer_type_id=b.type_id ) select * from cte
------解决方案--------------------
完全排列成树状结构应该不行。因为你不知道到底有几层目录结构。
大致可以使用如下的结构语句:
with tb as ( select 0 as id, -1 as id2 union all select 1 as id, 0 as id2 union all select 382 as id, 0 as id2 union all select 383 as id, 382 as id2 union all select 385 as id, 0 as id2 union all select 386 as id, 385 as id2 ) select tb.id, tb2.id from tb left outer join tb tb2 on tb.id = tb2.id2 order by tb.id, tb2.id2
------解决方案--------------------
-->这样么? ; with cte as ( select from 表 where TYPE_ID=0 union all select b.* from cte c,表 b where b.PER_TYPE_ID=c.TYPE_ID ) select * from cte