Skip to content
pvmehta.com

pvmehta.com

  • Home
  • About Me
  • Toggle search form
  • How to find password change date for user Oracle
  • fkwoind.sql fkwoindex.sql Oracle
  • SYSOPER Mystery Oracle
  • Privileges Required to Create Procedures and Functions that uses objects from other schema. Oracle
  • How to hide author name in WordPress BLOG PHP/MYSQL/Wordpress
  • findx.sql /* Find Indexes on specified USER.TABLE_NAME */ Oracle
  • Key Management in Oracle: The Core Issue: Missing Master Key Oracle
  • Jai Shree Ram Oracle
  • cold backup scripts to copy locally Linux/Unix
  • good linux notes Linux/Unix
  • Insert cause enqueue locks Oracle
  • Oracle vs MYSQL Architecture differences (For DBAs) MYSQL
  • Renaming Global Name GLOBAL_NAME Oracle
  • Postgres DB user and OS user. POSTGRESQL
  • send attachment from unix-shell script Linux/Unix

Display the top 5 salaries for each department using single SQL

Posted on 03-May-2010 By Admin No Comments on Display the top 5 salaries for each department using single SQL

Ok, given the clarification I can show you a way to get this in 815 and before (slow on a

big table) and in 816 and up (fast with analytic functions!)

ops$tkyte@ORA817.US.ORACLE.COM> select * from t;

DEPTNO SAL

———- ———-

10 100

10 100

10 200

10 300

10 400

10 500

20 100

20 200

20 300

20 400

20 500

20 600

20 700

20 700

30 100

30 200

30 300

30 400

18 rows selected.

Thats my sample data. Now to get it in 815 and before:

ops$tkyte@ORA817.US.ORACLE.COM>

ops$tkyte@ORA817.US.ORACLE.COM>

ops$tkyte@ORA817.US.ORACLE.COM> select distinct *

2 from t t1

3 where 5 >= ( select count(distinct t2.sal)

4 from t t2

5 where t2.deptno = t1.deptno

6 and t2.sal >= t1.sal )

7 /

DEPTNO SAL

———- ———-

10 100

10 200

10 300

10 400

10 500

20 300

20 400

20 500

20 600

20 700

30 100

30 200

30 300

30 400

14 rows selected.

And now using a new feature of 816:

ops$tkyte@ORA817.US.ORACLE.COM> select distinct *

2 from ( select deptno, sal,

3 dense_rank() over ( partition by deptno order by sal desc ) rank

4 from t )

5 where rank <= 5
6 /

DEPTNO SAL RANK

———- ———- ———-

10 100 5

10 200 4

10 300 3

10 400 2

10 500 1

20 300 5

20 400 4

20 500 3

20 600 2

20 700 1

30 100 4

30 200 3

30 300 2

30 400 1

14 rows selected.

Oracle, SQL scripts

Post navigation

Previous Post: import-export with multiple files
Next Post: find_longsql.sql

Related Posts

  • Multiple listeners Oracle
  • Temporary Tablespsace Temp tablespace behaviour Oracle
  • Absolute file number and relative file number Oracle
  • get_vmstat_solaris Oracle
  • FRA Information. Oracle
  • segment_wise_space.sql segspace.sql Segment wise space usage (allocated and used) Oracle

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Categories

  • Ansible (0)
  • AWS (2)
  • Azure (1)
  • Django (0)
  • GIT (1)
  • Linux/Unix (150)
  • MYSQL (5)
  • Oracle (403)
  • PHP/MYSQL/Wordpress (10)
  • POSTGRESQL (1)
  • Power-BI (0)
  • Python/PySpark (7)
  • RAC (18)
  • rman-dataguard (26)
  • shell (151)
  • SQL scripts (349)
  • SQL Server (6)
  • Uncategorized (5)
  • Videos (0)

Recent Posts

  • Key Management in Oracle: The Core Issue: Missing Master Key12-May-2026
  • SAT Mathematics 10 questions and answer at the end.30-Apr-2026
  • top 10 AI news today30-Apr-2026
  • runon_allpdbs_show_conname.sh23-Apr-2026
  • runon_allcdbs_find_pdbs.sh23-Apr-2026
  • Running PDB on single node in RAC09-Apr-2026
  • find_arc.sql09-Apr-2026
  • pvm_pre_change.sql08-Apr-2026
  • find_encr_wallet.sql08-Apr-2026
  • find_pdbs.sql08-Apr-2026

Archives

  • 2026
  • 2025
  • 2024
  • 2023
  • 2010
  • 2009
  • 2008
  • 2007
  • 2006
  • 2005
  • v$backup.status information Oracle
  • Rman Notes -1 Oracle
  • Finding locked objects Oracle
  • OEM-troubleshooting on 20-MAY-08 Oracle
  • Updated LCK.SQL file. Oracle
  • find_arc.sql Oracle
  • How to find password change date for user Oracle
  • Useful Solaris Commands on 28-SEP-2005 Linux/Unix

Copyright © 2026 pvmehta.com.

Powered by PressBook News WordPress theme