troubleshooting Question

MS SQL order by with "over" statement and row_number()

Avatar of Brad Bansner
Brad Bansner asked on
Microsoft SQL ServerMicrosoft SQL Server 2005
11 Comments1 Solution244 ViewsLast Modified:
I have a query I use frequently that someone helped me write several years ago, which I often create variations on. I thought I understood exactly what it does, but I am finding a discrepancy with the "order by" that I don't understand.

This query does what I want, which is simply an alphabetical sort on the "description" column:

select distinct
	description
from
	(select row_number() over (order by description) as rownum, description
		from tbl_product
		where (itemid='LUGS & H-TAPS : YAV2CLTC10FX' or itemid='LUGS & H-TAPS : YAV2CL2TC14E2FX')) as qryresults

RESULT:

description
"LUG COMPRESSION # 2 AWG FLEX 1 HOLE #10 STUD STANDARD BARREL 0.68"" TONGUE WIDTH BROWN W/ INSP WNDW BURNDY"
"LUG COMPRESSION # 2 AWG FLEX 2 HOLE 1/4"" STUD 3/4"" CENTER STANDARD BARREL 0.68"" TONGUE WIDTH BROWN W/ INSP WNDW BURNDY"

This query returns the same two results, but the "order by" is backwards:

select distinct
	itemid, description
from
	(select row_number() over (order by description) as rownum, itemid, description
		from tbl_product
		where (itemid='LUGS & H-TAPS : YAV2CLTC10FX' or itemid='LUGS & H-TAPS : YAV2CL2TC14E2FX')) as qryresults

RESULT:

itemid 	description
LUGS & H-TAPS : YAV2CL2TC14E2FX	"LUG COMPRESSION # 2 AWG FLEX 2 HOLE 1/4"" STUD 3/4"" CENTER STANDARD BARREL 0.68"" TONGUE WIDTH BROWN W/ INSP WNDW BURNDY"
LUGS & H-TAPS : YAV2CLTC10FX	"LUG COMPRESSION # 2 AWG FLEX 1 HOLE #10 STUD STANDARD BARREL 0.68"" TONGUE WIDTH BROWN W/ INSP WNDW BURNDY"

The only difference between the two is the "itemid" column present in the "select" clause (twice). I'm not understanding why selecting that column should cause the sorting to be backwards.

Thank you!
ASKER CERTIFIED SOLUTION
Join our community to see this answer!
Unlock 1 Answer and 11 Comments.
Start Free Trial
Learn from the best

Network and collaborate with thousands of CTOs, CISOs, and IT Pros rooting for you and your success.

Andrew Hancock - VMware vExpert
See if this solution works for you by signing up for a 7 day free trial.
Unlock 1 Answer and 11 Comments.
Try for 7 days

”The time we save is the biggest benefit of E-E to our team. What could take multiple guys 2 hours or more each to find is accessed in around 15 minutes on Experts Exchange.

-Mike Kapnisakis, Warner Bros