আমার নিম্নলিখিত স্কিমা (নাম পরিবর্তন হয়েছে), যা আমি পরিবর্তন করতে পারি না:
CREATE TABLE MyTable (
Id INT NOT NULL PRIMARY KEY,
ParentId INT NOT NULL
);
ALTER TABLE MyTable ADD FOREIGN KEY (ParentId) REFERENCES MyTable(Id);
অর্থাৎ, প্রতিটি রেকর্ড অন্য রেকর্ডের শিশু। যদি কোনও রেকর্ড এর ParentId
সমান হয় Id
তবে রেকর্ডটিকে মূল নোড হিসাবে বিবেচনা করা হয়।
আমি ক্যোয়ারি চালাতে চাই যা সমস্ত বিজ্ঞপ্তি রেফারেন্সগুলি খুঁজে পাবে। উদাহরণস্বরূপ, ডেটা সহ
INSERT INTO MyTable (Id, ParentId) VALUES
(0, 0),
(1, 0),
(2, 4),
(3, 2),
(4, 3);
কোয়েরিটি ফিরে আসা উচিত
Id | Cycle
2 | 2 < 4 < 3 < 2
3 | 3 < 2 < 4 < 3
4 | 4 < 3 < 2 < 4
আমি এসকিউএল সার্ভার ২০০৮ আর 2 এর জন্য নিম্নলিখিত কোয়েরিটি লিখেছি এবং আমি এই প্রশ্নটি আরও উন্নত করা যায় কিনা তা নিয়ে ভাবছি:
IF OBJECT_ID(N'tempdb..#Results') IS NOT NULL DROP TABLE #Results;
CREATE TABLE #Results (Id INT, HasParentalCycle BIT, Cycle VARCHAR(MAX));
DECLARE @i INT,
@j INT,
@flag BIT,
@isRoot BIT,
@ids VARCHAR(MAX);
DECLARE MyCursor CURSOR FAST_FORWARD FOR
SELECT Id
FROM MyTable;
OPEN MyCursor;
FETCH NEXT FROM MyCursor INTO @i;
WHILE @@FETCH_STATUS = 0
BEGIN
IF OBJECT_ID(N'tempdb..#Parents') IS NOT NULL DROP TABLE #Parents;
CREATE TABLE #Parents (Id INT);
SET @ids = NULL;
SET @isRoot = 0;
SET @flag = 0;
SET @j = @i;
INSERT INTO #Parents (Id) VALUES (@j);
WHILE (1=1)
BEGIN
SELECT
@j = ParentId,
@isRoot = CASE WHEN ParentId = Id THEN 1 ELSE 0 END
FROM MyTable
WHERE Id = @j;
IF (@isRoot = 1)
BEGIN
SET @flag = 0;
BREAK;
END
IF EXISTS (SELECT 1 FROM #Parents WHERE Id = @j)
BEGIN
INSERT INTO #Parents (Id) VALUES (@j);
SET @flag = 1;
SELECT @ids = COALESCE(@ids + ' < ', '') + CAST(Id AS VARCHAR) FROM #Parents;
BREAK;
END
ELSE
BEGIN
INSERT INTO #Parents (Id) VALUES (@j);
END
END
INSERT INTO #Results (Id, HasParentalCycle, Cycle) VALUES (@i, @flag, @ids);
FETCH NEXT FROM MyCursor INTO @i;
END
CLOSE MyCursor;
DEALLOCATE MyCursor;
SELECT Id, Cycle
FROM #Results
WHERE HasParentalCycle = 1;
না, 0 একটি মূল নোড, কারণ এটি এর
—
cubetwo1729
ParentId
সমান Id
, তাই এটি এই দৃশ্যের জন্য একটি চক্র নয়।
0 > 0
একটি চক্র বিবেচনা করা উচিত?