作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下 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
只获取每个值一次试试这个
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/
我有 2 个表 FormFields 和 Values。我需要从 FormFields 表中选择行并设置为列名。之后它应该用 Values 表中的值填充这些列。 Values 有 GroupId 每个
我有以下 SQL 查询 Select Product_Id, [riy] AS [riy], [eas] AS [eas] FROM (SELECT Product_Id, Store_N
我是一名优秀的程序员,十分优秀!