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

Oracle/Sybase SQL - obtenir une valeur basée sur un enregistrement précédent (pas un simple LAG)

Une façon d'y parvenir est d'utiliser des fonctions de classement imbriquées. Tout d'abord, attribuez une valeur constante à tout ce qui obtient une valeur (en utilisant max() over ) puis utilisez-le comme partition.

select t.Invoice_Id, t.Invoice_Line, t.Kit_Flag, t.Part_Number,
       max(KitPart) over (partition by invoice_id, KitNum) as Parent_Part
from (select t.*,
             sum(isKit) over (partition by InvoiceId order by InvoiceLine) as KitNum
      from (select t.Invoice_Id, t.Invoice_Line, t.Kit_Flag, t.Part_Number,
                   (case when Kit_Flag = 'K' then 1 else 0 end) as IsKit,
                   (case when Kit_Flag = 'K' then Part_Number end) as KitPart
            from Invoice_Data t
           ) t
     ) t