sql >> Databasteknik >  >> RDS >> Oracle

Hur jämför man värden för sista och näst sista posten i tabellen?

SELECT  *, value - nextvalue AS diff
FROM    (
        SELECT  m.*, LEAD(value) OVER (ORDER BY date DESC) AS nextvalue
        FROM    mytable m
        ORDER BY
                date DESC
        )
WHERE   rownum = 1

Uppdatering:

För att välja resultat företagsmässigt:

SELECT  value - nextvalue AS diff
FROM    (
        SELECT  m.*,
                LEAD(value) OVER (PARTITION BY companyId ORDER BY date DESC) AS nextvalue,
                ROW_NUMBER() OVER (PARTITION BY companyId ORDER BY date DESC) AS rn
        FROM    mytable m
        )
WHERE   rn = 1



  1. PostgreSql INSERT FRÅN SELECT RETURNING ID

  2. break row_number() sekvens baserad på flaggvariabel

  3. grupp efter intervall i mysql

  4. SQL SELECT hoppa över de första N resultaten?