gpt4 book ai didi

sql - 从 CTE 更新表中的记录

转载 作者:行者123 更新时间:2023-12-01 17:40:55 24 4
gpt4 key购买 nike

我有以下 CTE,它将为我提供整个发票的 DocTotal。

 ;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

关于sql - 从 CTE 更新表中的记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11562536/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com