sql >> Database >  >> RDS >> Oracle

Selecteer min. drie waarden van een record in een andere tabel met een JOIN

Als de vereiste blijft voor een spil van 3 prijzen in een reeks, gebruik dan ROW_NUMBER() maakt het mogelijk om deze nummers 1, 2, 3 te geven en vanaf daar is een eenvoudig gebruik van case expressions met een group by :

voor 3 laagste prijzen:

SELECT
      a.article_id
    , MAX(CASE
            WHEN a.price_seq = 1 THEN p.price END) AS price_1
    , MAX(CASE
            WHEN a.price_seq = 2 THEN p.price END) AS price_2
    , MAX(CASE
            WHEN a.price_seq = 3 THEN p.price END) AS price_3
FROM (
            SELECT
                  article_id
                , price_valid_from
                , price_id
                , ROW_NUMBER() OVER (PARTITION BY article_id
                                     ORDER BY p.price ASC) AS price_seq
            FROM article
                  LEFT OUTER JOIN price p
                              ON (a.price_id = p.price_id)
      ) a
GROUP BY
      a.article_id
ORDER BY
      a.article_id

voor 3 meest recente prijzen

SELECT
      a.article_id
    , MAX(CASE
            WHEN a.price_seq = 1 THEN p.price END) AS price_1
    , MAX(CASE
            WHEN a.price_seq = 2 THEN p.price END) AS price_2
    , MAX(CASE
            WHEN a.price_seq = 3 THEN p.price END) AS price_3
FROM (
            SELECT
                  article_id
                , price_valid_from
                , price_id
                , ROW_NUMBER() OVER (PARTITION BY article_id
                                     ORDER BY price_valid_from DESC) AS price_seq
            FROM article
      ) a
      LEFT OUTER JOIN price p
                  ON (a.price_id = p.price_id)
GROUP BY
      (a.article_id)
ORDER BY
      a.article_id

Demo SQLfiddle



  1. Verwijder nummers gevonden in stringkolom

  2. Beperkingen voor externe sleutels:wanneer moet u ON UPDATE en ON DELETE gebruiken?

  3. SQL SELECT eerste N resultaten overslaan?

  4. SELECTEER alle records die 30 dagen oud zijn