sql >> Databáze >  >> RDS >> Oracle

Jak zkombinuji svých 5 nejlepších platů a 5 nejnižších platů pro zobrazení v Oracle?

Použijte UNION nebo UNION ALL :

SELECT SAL FROM
(
SELECT DISTINCT SAL FROM EMP WHERE SAL IS NOT NULL ORDER BY SAL DESC
)
WHERE ROWNUM < 6
UNION ALL
SELECT SAL FROM
(
SELECT DISTINCT SAL FROM EMP WHERE SAL IS NOT NULL ORDER BY SAL ASC
)
WHERE ROWNUM < 6;

Můžete to také napsat stručněji jako:

SELECT SAL
FROM (SELECT DISTINCT SAL,
             DENSE_RANK() OVER (ORDER BY sal) as seqnum_asc,
             DENSE_RANK() OVER (ORDER BY sal) as seqnum_desc
      FROM EMP
      WHERE SAL IS NOT NULL
     ) s
WHERE seqnum_asc < 6 OR seqnum_desc < 6;



  1. Klauzule Oracle WITH nevrací žádná data

  2. Jak získat aktuální datum v SQLite

  3. Vytvořit přílohu... Vyberte příkaz v Laravel

  4. Cheat Sheet pro konfiguraci PostgreSQL