August 7, 2013 at 6:37 am
Hi,
I have table structure as shown in the below image. I have attached script for the table with sample data.
There is parent child relation between Time_Id and Parent_Id columns.
I want output rows in the following order. Basically all the root nodes(with NULL parent_id) should be in the order of SortOrder column. But at the same time if root has childs, all the childs should immediately appear below the root in the sorted order.
Can you please help ?
Thanks.
August 7, 2013 at 7:20 am
Since the sortorder column isn't particularly useful, why don't you populate it with the sort order that you actually want?
For fast, accurate and documented assistance in answering your questions, please read this article.
Understanding and using APPLY, (I) and (II) Paul White
Hidden RBAR: Triangular Joins / The "Numbers" or "Tally" Table: What it is and how it replaces a loop Jeff Moden
August 7, 2013 at 7:25 am
I am really not sure but this is that table structure with data that is given to me. Would really be a great help if someone can help. I already tried recursive CTE's, using ROW_NUMBERs etc but was not able to get the required output.
August 7, 2013 at 7:27 am
Is this what you're after?
WITH Source AS (
SELECT [TIME_ID],
, [DESCRIPTION], [PARENT_ID], CAST(1000+ROW_NUMBER() OVER(ORDER BY [SORTORDER]) AS VARCHAR(10)) AS [SORTORDER]
FROM tblTime),
Recur AS (
SELECT [TIME_ID], , [DESCRIPTION], [PARENT_ID], CAST([SORTORDER] AS VARCHAR(1000)) AS [SORTORDER]
FROM Source
WHERE [PARENT_ID] IS NULL
UNION ALL
SELECT t.[TIME_ID], t., t.[DESCRIPTION], t.[PARENT_ID], CAST(r.[SORTORDER] + '/' + t.[SORTORDER] AS VARCHAR(1000))
FROM Source t
INNER JOIN Recur r ON r.[TIME_ID] = t.[PARENT_ID])
SELECT [TIME_ID], , [DESCRIPTION], [PARENT_ID]
FROM Recur
ORDER BY [SORTORDER];
____________________________________________________
Deja View - The strange feeling that somewhere, sometime you've optimised this query before
How to get the best help on a forum
http://www.sqlservercentral.com/articles/Best+Practices/61537August 7, 2013 at 7:28 am
rajg (8/7/2013)
I am really not sure but this is that table structure with data that is given to me. Would really be a great help if someone can help. I already tried recursive CTE's, using ROW_NUMBERs etc but was not able to get the required output.
I mean, just for the sample data.
For fast, accurate and documented assistance in answering your questions, please read this article.
Understanding and using APPLY, (I) and (II) Paul White
Hidden RBAR: Triangular Joins / The "Numbers" or "Tally" Table: What it is and how it replaces a loop Jeff Moden
August 7, 2013 at 7:35 am
This is perfect...Thankkkkk you very much !! Dont know why I spent so much of time on this
August 7, 2013 at 7:35 am
rajg (8/7/2013)
This is perfect...Thankkkkk you very much !! Dont know why I spent so much of time on this
You're welcome.
____________________________________________________
Deja View - The strange feeling that somewhere, sometime you've optimised this query before
How to get the best help on a forum
http://www.sqlservercentral.com/articles/Best+Practices/61537August 7, 2013 at 7:44 am
I had tried number of ways with row number and CTE...but never thought of adding '/' between parent and child sortorder field...I was trying addition, simple concatenation.
Could you please help me to understand how that '/' helps to get the required data ?
August 7, 2013 at 7:49 am
You don't actually need the '/', that's just for clarity to show the sort order for each part of the hierarchy. The sort order value just has to be fixed width - four characters in this case (1001 onwards).
____________________________________________________
Deja View - The strange feeling that somewhere, sometime you've optimised this query before
How to get the best help on a forum
http://www.sqlservercentral.com/articles/Best+Practices/61537Viewing 9 posts - 1 through 8 (of 8 total)
You must be logged in to reply to this topic. Login to reply
This website stores cookies on your computer.
These cookies are used to improve your website experience and provide more personalized services to you, both on this website and through other media.
To find out more about the cookies we use, see our Privacy Policy