SQL सर्वर पुनरावर्ती स्व शामिल



sql-server recursion (1)

मेरे पास निम्न कॉलम के साथ एक साधारण श्रेणी तालिका है:

  • ईद
  • नाम
  • मूल आईडी

तो, श्रेणियों की एक अनंत राशि एक श्रेणी का बच्चा हो सकता है। उदाहरण के लिए निम्न पदानुक्रम लें:

मैं चाहता हूं, एक साधारण क्वेरी में जो "बिजनेस लैपटॉप" श्रेणी देता है, वह भी एक कॉलम है जिसमें सभी माता-पिता, अल्पविराम विभाजक या कुछ और हैं:

या निम्नलिखित उदाहरण लें:


बचाव के लिए पुनरावर्ती सीटी ...।

नमूना तालिका बनाएं और आबाद करें ( कृपया अपने भविष्य के प्रश्नों में हमें इस चरण को बचाएं):

DECLARE @T as table
(
    id int,
    name varchar(100),
    parent_id int
)

INSERT INTO @T VALUES
(1, 'A', NULL),
(2, 'A.1', 1),
(3, 'A.2', 1),
(4, 'A.1.1', 2),
(5, 'B', NULL),
(6, 'B.1', 5),
(7, 'B.1.1', 6),
(8, 'B.2', 5),
(9, 'A.1.1.1', 4),
(10, 'A.1.1.2', 4)

Cte:

;WITH CTE AS
(
    SELECT id, name, name as path, parent_id
    FROM @T 
    WHERE parent_id IS NULL
    UNION ALL
    SELECT t.id, t.name, cast(cte.path +','+ t.name as varchar(100)), t.parent_id
    FROM @T t
    INNER JOIN CTE ON t.parent_id = CTE.id
)

पूछताछ:

SELECT id, name, path
FROM CTE

परिणाम:

id      name        path
1       A           A
5       B           B
6       B.1         B,B.1
8       B.2         B,B.2
7       B.1.1       B,B.1,B.1.1
2       A.1         A,A.1
3       A.2         A,A.2
4       A.1.1       A,A.1,A.1.1
9       A.1.1.1     A,A.1,A.1.1,A.1.1.1
10      A.1.1.2     A,A.1,A.1.1,A.1.1.2

ऑनलाइन डेमो देखें






recursion