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

Mise à jour T-SQL avec SUM et Group BY

Si cette requête renvoie les informations souhaitées :

SELECT *, LINE_TOTAL = SUM(l.LINE_TOTAL) OVER 
    (PARTITION BY l.IC_PO_HEADER, l.RELEASE_NUMBER)
  FROM dbo.PO_HEADER AS h
  INNER JOIN dbo.PO_LINE AS l
  ON h.IC_PO_HEADER = l.IC_PO_HEADER 
  AND h.RELEASE_NUMBER = l.RELEASE_NUMBER;

Alors c'est probablement la requête UPDATE que vous voulez :

;WITH x AS
(
  SELECT h.TOTAL, lt = SUM(l.LINE_TOTAL) OVER 
    (PARTITION BY l.IC_PO_HEADER, l.RELEASE_NUMBER)
  FROM dbo.PO_HEADER AS h
  INNER JOIN dbo.PO_LINE AS l
  ON h.IC_PO_HEADER = l.IC_PO_HEADER 
  AND h.RELEASE_NUMBER = l.RELEASE_NUMBER
)
UPDATE x SET TOTAL = lt;

Je suis d'accord avec Gordon, votre regroupement semble très étrange. Je ne sais pas si j'ai bien compris (c'est pourquoi je vous recommande fortement d'exécuter d'abord le SELECT).