How to find out department wise second maximum salary.

Showing Answers 1 - 35 of 35 Answers

Irfan

  • Mar 30th, 2006
 

Code
  1.  

  Was this answer useful?  Yes

sagar

  • Sep 29th, 2011
 

It's wrong.better to use dense_rank() function instead of rank() function

  Was this answer useful?  Yes

Mohan Rao

  • Nov 3rd, 2011
 

Code
  1.  

  Was this answer useful?  Yes

sharika

  • Nov 24th, 2011
 

Code
  1.  

  Was this answer useful?  Yes

srikanth

  • Jan 11th, 2012
 

Code
  1.  



  Was this answer useful?  Yes

SASI

  • Apr 7th, 2012
 

Code
  1.  

  Was this answer useful?  Yes

Ashok

  • May 4th, 2012
 

What is the length of column in oracle?

  Was this answer useful?  Yes

smily08

  • Aug 30th, 2012
 

select max(salary) from EMP
WHERE SALARY < (SELECT MAX(SALARY) FROM EMP where dept = Dept1) and dept = Dept1

  Was this answer useful?  Yes

Nazeera Jaffar

  • Sep 25th, 2012
 

Code
  1.  

  Was this answer useful?  Yes

Mrinal

  • Dec 14th, 2012
 

Code
  1.  

  Was this answer useful?  Yes

Dasish

  • Dec 12th, 2014
 

Select a.empno, a.deptno, a.sal from emp a, emp b where a.sal <= b.sal group by a.empno, a.deptno, a.sal having count( distinct b.sal) = ∈

  Was this answer useful?  Yes

Ejaz Ahmed

  • Apr 18th, 2015
 

1. SELECT deptno, MAX(sal) "SAL"
2. FROM emp
3. WHERE (deptno,sal) NOT IN (SELECT deptno,MAX(sal)
4. FROM emp
5. GROUP BY deptno)
6. GROUP BY deptno

  Was this answer useful?  Yes

Bismaya

  • Sep 2nd, 2015
 

It wont work as it returns more than row in single row subquery.

  Was this answer useful?  Yes

Nitin Tomer

  • Nov 4th, 2016
 

Below is the data set:

SALARY DEPT
1000 q1
2000 q1
3000 q1
4000 q1
5000 q2
5000 q2
7000 q2
8000 q2
1000 q3
2000 q3
3000 q3
4000 q3
5000 q4
5000 q4
7000 q4
8000 q4

Here i am trying to achieve 2nd highest salary dept wise.

SELECT * FROM (SELECT SALARY,UPPER(DEPT) ,RANK()OVER(PARTITION BY DEPT ORDER BY SALARY) RNK FROM TEST_DATA)
WHERE RNK=2;

In case of RANK() we may get same rank for the same salary in the same department so in that case it will not give the correct result and It will give the next value also wrong(e.g. after repeating the value 2,2,2 next rank it will give 3) which will make all rank wrong and not useful for further use.
SELECT * FROM(
SELECT SALARY,UPPER(DEPT) ,DENSE_RANK()OVER(PARTITION BY DEPT ORDER BY SALARY) DRNK FROM TEST_DATA.

DENSE_RANK() will also do the same thing as rank just one thing it will not give the next value after repeating a value(e.g. after repeating 2,2,2 three times it will give next dense_rank value as 5) but again if we want to see the second highest salary it will show 3 values for dense_rank 2.
)WHERE DRNK=2;

SELECT * FROM(
SELECT SALARY,UPPER(DEPT) ,ROW_NUMBER()OVER(PARTITION BY DEPT ORDER BY SALARY) RNM FROM TEST_DATA;

Here it will give the exact value which we are looking for. So the best way to calculate highest values department wise use row_number(), it will always give the correct result.

please let me know for any concerns

  Was this answer useful?  Yes

SIDDHARTHA PENCHALA

  • Nov 27th, 2016
 

Can you please explain its internal process?

  Was this answer useful?  Yes

PRUDHVI

  • Dec 5th, 2016
 

Code
  1.  

  Was this answer useful?  Yes

KAMLESH

  • Dec 28th, 2016
 

Code
  1.  

  Was this answer useful?  Yes

pinky

  • May 31st, 2017
 

SELECT * FROM (SELECT DEPT_ID , DENSE_RANK(SALARY) OVER(PARTITION BY DEPT_ID ORDER BY SALARY ) DRANK FROM DEPARTMENTS ) WHERE DRANK = 2;

  Was this answer useful?  Yes

Give your answer:

If you think the above answer is not correct, Please select a reason and add your answer below.

 

Related Answered Questions

 

Related Open Questions