1. ホーム
  2. sql

CTEからテーブルのレコードを更新する

2023-10-03 05:03:35

質問

請求書全体のDocTotalを得るために、以下のCTEを持っています。

 ;WITH CTE_DocTotal
 AS
 (
   SELECT SUM(Sale + VAT) AS DocTotal
   FROM PEDI_InvoiceDetail
   GROUP BY InvoiceNumber
 )

UPDATE PEDI_InvoiceDetail
SET DocTotal = CTE_DocTotal.DocTotal

さて、この結果をもとに、PEDI_InvoiceDetailのDocTotalの値をカラムに入力したいと思います。

うまくいかないのは分かっていますし、何かを見逃しているのも分かっています。

どのように解決するには?

CTEに行った更新は、ソーステーブルにカスケードされます。

あなたのスキーマを少し推測しなければなりませんでしたが、このようなものが動作するはずです。

;WITH T AS
(   SELECT  InvoiceNumber, 
            DocTotal, 
            SUM(Sale + VAT) OVER(PARTITION BY InvoiceNumber) AS NewDocTotal
    FROM    PEDI_InvoiceDetail
)
UPDATE  T
SET     DocTotal = NewDocTotal