我想在此查询的值进行更新,但它说,它返回多个值。
UPDATE PO_HEADER
SET TOTAL = (SELECT SUM(LINE_TOTAL) AS "NEW_LINE_TOTAL"
FROM PO_LINE pl, PO_HEADER ph
where ph.IC_PO_HEADER = pl.IC_PO_HEADER
and ph.RELEASE_NUMBER = pl.RELEASE_NUMBER
group by pl.IC_PO_HEADER,pl.FOREIGN_KEY,ph.RELEASE_NUMBER,
ph.REVISION_NUMBER,ph.PO_NUMBER)
from PO_HEADER ph, PO_LINE pl
where ph.IC_PO_HEADER = pl.IC_PO_HEADER;
消息512,级别16,状态1,第1行
子查询返回多个值。 这是当子查询如下=,!=,<,<=,>,> =,或当子查询用作表达不允许的。
它是如何返回多列多?
如果该查询返回的信息,你想:
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;
那么这可能是你想要更新查询:
;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;
我与戈登同意,您的分组似乎很奇怪。 我不知道如果我这样做是正确(这就是为什么我强烈建议你运行SELECT第一)。
因为子查询选择将返回多行它返回一个以上的列。
也许你的意思是更多的东西是这样的:
with toupdate as (
SELECT SUM(LINE_TOTAL) AS "NEW_LINE_TOTAL"
FROM PO_LINE pl join
PO_HEADER ph
on ph.IC_PO_HEADER = pl.IC_PO_HEADER and
ph.RELEASE_NUMBER = pl.RELEASE_NUMBER
group by pl.IC_PO_HEADER, pl.FOREIGN_KEY, ph.RELEASE_NUMBER,
ph.REVISION_NUMBER, ph.PO_NUMBER
)
UPDATE PO_HEADER
SET TOTAL = toupdate. New_Line_Total
from toupdate
where PO_HEADER.IC_PO_HEADER = toupdate.IC_PO_HEADER;
我仍然怀疑这一点,虽然,因为你是由5个字段在子查询分组,但只有在加盟其中之一。 我希望“更新所”是仅在这种情况下ic_po_header分组。