sql >> Database >  >> RDS >> Oracle

Hoe de waarden voor de laatste en voorlaatste invoer in de tabel te vergelijken?

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

Bijwerken:

Om bedrijfsresultaten te selecteren:

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. het creëren van geparametriseerde views in oracle11g

  2. Resultaten binnen een straal - Optimalisatie van langzame MySQL-query

  3. mysql draaitabeldatum (verticale naar horizontale gegevens)

  4. Emacs en MySQL op Mac