T-SQL: how to sort table rows based on 2 columns
- by Criss Nautilus
I'm quite stuck with this problem for sometime now..
How do I sort column A depending on the contents of Column B?
I have this sample:
ID count columnA ColumnB
12 1 A B
13 2 C D
14 3 B C
I want to sort it like this:
ID count ColumnA ColumnB
12 1 A B
14 3 B C
13 2 C D
so I need to sort the rows if the previous row of ColumnB = the next row of ColumnA
I'm thinking a loop? but can't quite imagine how it will work...
I was thinking it will go like this (maybe)
SELECT a.ID, a.ColumnA, a.ColumnB
FROM TableA WITH a (NOLOCK)
LEFT JOIN TableA b WITH (NOLOCK)
ON a.ID = b.ID
and a.counts = b.counts
Where a.columnB = b.ColumnA
the above code isn't working though and I was thinking more on the lines of...
DECLARE @counts int = 1
DECLARE @done int = 0
--WHILE @done = 0
BEGIN
SELECT a.ID, a.ColumnA, a.ColumnB
FROM TableA WITH a (NOLOCK)
LEFT JOIN TableA b WITH (NOLOCK)
ON a.ID = b.ID
and a.counts = @counts
Where a.columnB = b.ColumnA
set @count = @count +1
END
If this was a C code, would be easier for me but t-sql's syntax is making it a bit harder for a noobie like me.