gpt4 book ai didi

sql - 多次为 '638' 指定列 'PVT'。枢

转载 作者:行者123 更新时间:2023-12-02 08:17:49 25 4
gpt4 key购买 nike

我有以下 SQL 查询

Select Product_Id, [riy] AS [riy],
[eas] AS [eas]
FROM
(SELECT Product_Id, Store_Name, Quantity
FROM [Product_Stock] INNER JOIN Store on Store.Id = [Product_Stock].Stock_Id where Product_Id = 435) ps
PIVOT
(
SUM(Quantity)
FOR Store_Name IN
([riy],[EAST WAREHOUSE - eas])
) AS pvt

它给出了预期的结果。为我提供了 riy 和 eas 的总数量。

但是,我想动态获取 Store 名称,而不是手动指定它们。

这就是我所做的。

DECLARE @cols AS NVARCHAR(MAX),
@query AS NVARCHAR(MAX)

SELECT @cols = STUFF((SELECT ',' + QUOTENAME([Product_Id])
FROM [Product_Stock]
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')

SELECT @query =
'SELECT Product_Id FROM
(SELECT Product_Id, Store_Name, Quantity
FROM [Product_Stock] INNER JOIN Store on Store.Id = [Product_Stock].Stock_Id where Product_Id = 435) PS
PIVOT
(
SUM(Quantity)
FOR Store_Name in (' + @cols + ')
) AS PVT'

EXEC SP_EXECUTESQL @query

这给了我一个错误,说列“638”被多次指定为“PVT”。

我该如何解决这个问题?

最佳答案

在不知道您的实际数据的情况下,这是一次盲目飞行,但我认为您有两个问题:

  • 您必须使用 DISTINCT 只获取每个值一次
  • 您连接的不是商店名称,而是您产品的 ID

试试这个

SELECT @cols = STUFF((SELECT DISTINCT  ',' + QUOTENAME([Store_Name]) 
FROM [Product_Stock]
INNER JOIN Store on Store.Id = [Product_Stock].Stock_Id
FOR XML PATH(''), TYPE
).value('.', 'NVARCHAR(MAX)')
,1,1,'')

关于sql - 多次为 '638' 指定列 'PVT'。枢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40344837/

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