I have following table with some data to find second largest number.
Table:
ColA
---------
3
23
43
673
173
373
273
I have following table with some data to find second largest number.
Table:
ColA
---------
3
23
43
673
173
373
273
Use this:
select * from
(select colA , row_number() over(order by colA desc) as rn from Table) T
where T.rn=2
Thanks to Martin's / dnoeth's comment :
It can be problematic with 2 max inetegers
Use this :
select * from
(select colA , DENSE_RANK( ) OVER (ORDER BY colA ) as rn from Table) T
where T.rn=2
Additional info : (once and for all ( learn it! , I always use it)) :
DECLARE @t TABLE(NAME NVARCHAR(MAX),val money)
insert INTO @t SELECT 'a',100
insert INTO @t SELECT 'a',100
insert INTO @t SELECT 'a',100
insert INTO @t SELECT 'a',100
insert INTO @t SELECT 'b',200
insert INTO @t SELECT 'b',200
insert INTO @t SELECT 'd',400
insert INTO @t SELECT 'e',500
insert INTO @t SELECT 'f',600
select Name,
val,
ROW_NUMBER() OVER (PARTITION BY NAME ORDER BY name),
val/ SUM(val) OVER(PARTITION BY NAME ) AS '1AgainstTotalHimself',
val/ SUM(val) OVER( ) AS '1AgainstOthers' ,
NTILE(2) OVER ( PARTITION BY NAME ORDER BY name) AS 'ntile2' ,
NTILE(2) OVER ( ORDER BY name) AS 'ntile' , -- ( 9%2=1 , so group #1 will get more number)
RANK( ) OVER ( ORDER BY name ) AS Rank,
DENSE_RANK( ) OVER (ORDER BY name) AS DENSERANK
from @t
Result :
One way to solve this would be
with cte as (
select ColA,
Row_number() over(order by ColA DESC) As rn
FROM Table
)
SELECT ColA
FROM cte
WHERE rn = 2
Update After Martin's correct comment, here is a better answer:
Select top 1 ColA
From YourTable
WHERE ColA < (
SELECT MAX(ColA)
FROM YourTable
)
ORDER BY ColA DESC