Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

A data máxima não funcionará, alternativa?


Eu acho que a resposta canônica para essa pergunta é a seguinte
with AllData as
(
select ... from ...
where ...
)
select * from allData ad1
inner join 
(
    select pk1, pk2, pk<n>, max(MaxThing) MaxVal 
    from AllData
    group by pk1, pk2, pk<n>
) as ad2 
on (ad1.pk1=ad2.pk1 and ad1.pk2=ad2.pk2 and ad1.pk<n>=ad2.pk<n> 
and  ad1.MaxThing=ad2.MaxVal)

No seu caso cst_recno é o PK e inv_trx_date é o MaxThing


No