Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

date la plus récente (max) pour chaque identifiant

vous pouvez sélectionner la date maximale pour chaque groupe d'identifiants comme

SELECT a,
    b,
    max(b) OVER (PARTITION BY a) AS c
FROM myTable
ORDER BY a,b

MODIF : l'une des solutions possibles pour la deuxième partie (modifiée) de la question est

WITH cte AS (
    SELECT a,
        b,
        max(b) OVER (PARTITION BY a) AS c,
        d
    FROM myTable
)
SELECT t1.a,
    t1.b,
    t1.c,
    t1.d,
    t2.d AS e
FROM cte t1
JOIN cte t2 ON t1.a=t2.a AND t1.c=t2.b