7

私はテーブルカテゴリを持っています、

1) ID
2) カテゴリ
名 3) カテゴリマスター

1コンピュータ

0
2 ソフトウェア 1
3 マルチメディア 1
4 アニメーション 3
5 Health 0
6 Healthsub 5

そして私は次のように再帰クエリを作成しました:

 ;WITH CategoryTree AS
 (
  SELECT *, CAST(NULL AS VARCHAR(50)) AS ParentName, 0 AS Generation    
  FROM dbo.Category    
  WHERE CategoryName = 'Computers'

  UNION ALL        

  SELECT Cat.*,CategoryTree.CategoryName AS ParentName, Generation + 1    
  FROM dbo.Category AS Cat  INNER JOIN 
  CategoryTree ON Cat.CategoryMaster = CategoryTree.Id
 )

 SELECT * FROM CategoryTree

コンピュータのすべてのサブカテゴリを取得するように、親カテゴリの結果を一番下に取得します

しかし、私はアニメーションからコンピュータへのようなボトムアップからの結果が欲しいです.誰かが私に正しい方向を提案してくれませんか.

前もって感謝します :)

4

1 に答える 1

5

join 句のフィールドを交換するだけです。

WITH CategoryTree AS
        (
        SELECT  *, 0 AS Generation    
        FROM    dbo.Category
        WHERE   CategoryName = 'Animation'
        UNION ALL
        SELECT  Cat.*, Generation + 1    
        FROM    CategoryTree
        JOIN    dbo.Category AS Cat
        ON      Cat.Id = CategoryTree.CategoryMaster
        )
SELECT  *
FROM    CategoryTree
于 2011-01-14T11:10:00.853 に答える