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

Joindre deux tables, n'utiliser que la dernière valeur de la table de droite

Si SQL Server 2005+

;WITH m AS 
(
   SELECT Partnum, Formula, RevisionNum,
     rn = ROW_NUMBER() OVER (PARTITION BY PartNum ORDER BY 
       CASE WHEN RevisionNum ='New' THEN 1 ELSE 2 END)
     FROM dbo.Material
)
SELECT p.PartNum, m.Formula, m.RevisionNum
FROM dbo.Parts AS p
INNER JOIN m ON p.PartNum = m.PartNum
WHERE m.rn = 1;

Bien que curieux, que faites-vous lorsqu'il y a plus de 26 révisions (par exemple, ce qui vient après Z ) ?