gpt4 book ai didi

tsql - 如何向 GROUPING_ID 结果添加过滤器?

转载 作者:行者123 更新时间:2023-12-02 14:18:43 27 4
gpt4 key购买 nike

我有以下查询...

SELECT a.countryRegion, a.Stateprovince, SUM (soh.TotalDue) AS revenue,
CASE
WHEN GROUPING_ID(a.countryregion,a.stateprovince) = 0 THEN 'State/Province'
WHEN GROUPING_ID(a.countryregion,a.stateprovince) = 3 THEN 'Total'
WHEN GROUPING_ID(a.countryregion,a.stateprovince) = 1 THEN 'Country Total'
ELSE N'unknown'
END AS 'Level'
FROM saleslt.address AS a
JOIN saleslt.customeraddress AS ca
ON a.addressID = ca.addressID
JOIN saleslt.customer AS c
ON ca.customerID = c.customerID
JOIN salesLT.salesorderheader as soh
ON c.customerID = soh.customerID
GROUP BY ROLLUP(a.countryregion, a.stateprovince)
ORDER BY a.countryregion,a.stateprovince;

例如,如何获取包含值“美国小计”的“国家/地区”行以及包含“加利福尼亚州小计”值的州/省行?

该表包括大约 8 个不同的州/省和多个国家/地区。

最佳答案

您的 GROUP BY ROLLUP(a.countryregion, a.stateprovince) 语句应返回小计之前包含 NULL 值的字段。

您可以通过更改 select 语句来用“小计:”替换这些 NULL 值,如下所示:

SELECT 
coalesce(a.countryRegion,"Sub Total:") as countryRegion,
coalesce(a.Stateprovince, "Sub Total:") as Stateprovince, .............

您可以格式化报表输出以消除重复的小计,或使用子查询来清除重复。

您可以查看 LEAD() 和 LAG() 窗口函数,以从上一行获取 countryRegionStateProvince

关于tsql - 如何向 GROUPING_ID 结果添加过滤器?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46008732/

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