sql >> Database >  >> RDS >> Sqlserver

Hoe kunt u SQL gebruiken om waarden te retourneren voor een opgegeven datum of dichtstbijzijnde datum

Je zou zoiets als dit kunnen proberen:

SELECT date, grp, id
    , (SELECT TOP 1 price
       FROM price_table P2
       WHERE P1.id = P2.id
       AND P1.grp = P2.grp
       AND P2.date <= P1.date
       ORDER BY P2.date DESC)
FROM price_table P1
WHERE P1.date IN ('12/31/2009', '11/30/2009')
AND P1.grp IN ('Group1')

Bewerken Om het laatste record voor elke maand, groep en id te krijgen, kunt u dit proberen:

SELECT date, grp, id, price
FROM price_table P1
WHERE P1.date = (SELECT MAX(date)
                 FROM price_table P2
                 WHERE P1.grp = P2.grp
                 AND P1.id = P2.id
                 AND YEAR(P1.date) = YEAR(P2.date)
                 AND MONTH(P1.date) = MONTH(P2.date))
AND P1.grp In ('Group1')


  1. Sqoop op Dataproc kan geen gegevens exporteren naar Avro-indeling

  2. Is er een manier om ARRAY's te gebruiken in Entity Framework + PostgreSql?

  3. Beste werkwijze voor databaseversleuteling in SQL Server 2005

  4. Opgeslagen procedure en machtigingen - Is UITVOEREN voldoende?