ROLLUP,总计不同舍入

ROLLUP, Different rounding in grand total

相关:

问题是我想要不同的总计舍入精度。请考虑此代码:

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 位。有什么办法吗?

谢谢

不幸的是没有。您可以在整列上设置精度。您可以为一列中的不同行指定不同的格式。您按列指定格式。旋转你的结果对你的情况很有帮助。

唯一的方法是设置精度并将值转换为字符串,以便列类型相同。但你真的需要吗?

SELECT 
    Value1,
    case 
        when StateName is null and [Group] is null then cast(cast(Value1 as decimal(20, 2)) as varchar(30)) 
        when StateName is null and [Group] is not null then cast(cast(Value1 as decimal(20, 1)) as varchar(30)) 
        else cast(cast(Value1 as decimal(20, 2)) as varchar(30)) 
    end 
FROM T  
ORDER BY [Group]