I have a complex query with group by and order by clause and I need a sorted row number (1...2...(n-1)...n) returned with every row. Using a ROWNUM (value is assigned to a row after it passes the predicate phase of the query but before the query does any sorting or aggregation) gives me a non-sorted list (4...567...123...45...). I cannot use application for counting and assigning numbers to each row.
+8
A:
Is there a reason that you can't just do
SELECT rownum, a.*
FROM (<<your complex query including GROUP BY and ORDER BY>>) a
Justin Cave
2008-10-01 21:12:49
Well, at least than means that there would be two of us doing it that way, lol!
Carl
2008-10-01 21:14:11
Though we did use different aliases :-)
Justin Cave
2008-10-01 21:20:32
Thanks to both of you :)
Igor Drincic
2008-10-01 21:26:38
+3
A:
You could do it as a subquery, so have:
select q.*, rownum from (select... group by etc..) q
That would probably work... don't know if there is anything better than that.
Carl
2008-10-01 21:13:10
A:
Can you use an in-line query? ie
SELECT cols, ROWNUM
FROM (your query)
cagcowboy
2008-10-01 21:13:11
A:
Assuming that you're query is already ordered in the manner you desire and you just want a number to indicate what row in the order it is:
SELECT ROWNUM AS RowOrderNumber, Col1, Col2,Col3...
FROM (
[Your Original Query Here]
)
and replace "Colx" with the names of the columns in your query.
Mark Roddy
2008-10-01 21:14:57
A:
I also sometimes do something like:
SELECT * FROM
(SELECT X,Y FROM MY_TABLE WHERE Z=16 ORDER BY MY_DATE DESC)
WHERE ROWNUM=1
Osama ALASSIRY
2008-10-06 19:47:18
A:
If you want to use ROWNUM to do anything more than limit the total number of rows returned in a query (e.g. AND ROWNUM < 10) you'll need to alias ROWNUM:
select * (select rownum rn, a.* from () a)) where rn between 500 and 1000
zbonig
2010-07-27 14:25:59