This query was working perfectly fine and fast to complete when I almost have 500 rows in Member_Contact_Edges table. But now, I have nearly 1.000 rows in this table and this query takes 20-30 seconds to complete. I couldn't figure out where the problem is. I tried Clustered and Non-Clustered index. I tried every combination of indexes but no success.
;WITH transitive_closure(member_a, member_b, distance, path_string) AS
(SELECT member_a, member_b, 1 AS distance, CAST(member_a as varchar(MAX)) + '.' + CAST(member_b as varchar(MAX)) + '.' AS path_string
FROM Member_Contact_Edges
WHERE member_a = @source AND contact_durum=1 -- source
UNION ALL
SELECT tc.member_a, e.member_b, tc.distance + 1, CAST(tc.path_string as varchar(MAX)) + CAST(e.member_b as varchar(MAX)) + '.' AS path_string
FROM Member_Contact_Edges AS e
JOIN transitive_closure AS tc ON e.member_a = tc.member_b
WHERE tc.path_string NOT LIKE '%' + CAST(e.member_b as varchar(MAX)) + '.%' AND e.contact_durum=1
)
SELECT distance, path_string FROM transitive_closure
WHERE member_b=@target AND distance <= 3 -- destination
ORDER BY member_a, member_b, distance;
This is how I call Stored Procedure:
Exec Contacts_KacinciDerece @source = 30284, @target=24688
The output: (It's what I expected and this query creates this)
Thanks.