【发布时间】:2018-07-17 09:28:43
【问题描述】:
相关:Calculate group result and merge it with details
问题是我想要总计不同的舍入精度。请考虑以下代码:
DECLARE @tblStates AS Table
(
StateName VARCHAR(50),
Value1 DECIMAL(5,2),
Value2 DECIMAL(5,2),
Value3 DECIMAL(5,2)
)
INSERT INTO @tblStates VALUES('State1',103,23,3)
INSERT INTO @tblStates VALUES('State2',105,32,12)
INSERT INTO @tblStates VALUES('State3',150,2,23)
INSERT INTO @tblStates VALUES('State4',50,10,8)
INSERT INTO @tblStates VALUES('State5',80,22,1)
INSERT INTO @tblStates VALUES('State6',20,18,45)
DECLARE @tblStatesGroups AS Table
(
[Group] VARCHAR(50),
[State] VARCHAR(50)
)
INSERT INTO @tblStatesGroups VALUES('Group1','State1')
INSERT INTO @tblStatesGroups VALUES('Group1','State2')
INSERT INTO @tblStatesGroups VALUES('Group1','State3')
INSERT INTO @tblStatesGroups VALUES('Group2','State4')
INSERT INTO @tblStatesGroups VALUES('Group2','State5')
INSERT INTO @tblStatesGroups VALUES('Group2','State6')
;WITH T as
(
SELECT
groups.[Group],
StateName,
AVG(Value1) AS Value1,
AVG(Value2) AS Value2,
MIN(Value3) AS Value3
FROM @tblStates states inner join @tblStatesGroups groups on states.StateName = groups.[State]
GROUP BY ROLLUP(groups.[Group],StateName)
)
SELECT
CASE ISNULL(StateName,'') WHEN '' THEN [Group] ELSE StateName END AS StateName,
Value1,
Value2,
Value3
FROM T
ORDER BY [Group]
我希望小计有 1 个小数点精度,总计有 2 个小数点精度。有什么办法吗?
谢谢
【问题讨论】:
-
你能指定你的小计和总计在哪里吗?从问题上看不是很清楚。
标签: sql sql-server sql-server-2014 common-table-expression rollup