我正在尝试创建以下视图:
CREATE VIEW [dbo].[_TEST]
AS
SELECT
a.[PS],
b.[A0001],
CAST(a.[Area] AS DECIMAL(15, 10)) AS A0002,
CAST((b.[0001] / a.[Area]) AS DECIMAL(15, 10)) AS A0003
FROM
dbo.Areas AS a
INNER JOIN
(SELECT
LEFT(PSOA, 6) AS PS, SUM([0001]) as A0001
FROM
dbo.Counts
GROUP BY
LEFT(PSOA, 6) AS b ON a.PS = b.PS
视图创建得很好,但是使用它时出现以下错误:
将数字数据类型转换为数字的算术溢出错误
现在,根据我的理解,这意味着这些值太大而无法放入Decimal(15,10)
中。但是,手动计算它们,我得到的A0003
的最大值是2151.93382
,这对于Decimal(15,10)
来说很好。我什至尝试Decimal(20,10)
只是为了确保返回相同的错误。这些数字肯定不会太大,那么怎么了?
答案 0 :(得分:0)
这没有给出错误,并且该错误可能是由于其他原因引起的。检查可能大于此值的其他数据。
Select Cast(2151.93382 as Decimal(15,10))
您可以查看演示here。
我认为表SUM([0001])
中有多少行会产生大量数字,从而导致算术溢出异常。
答案 1 :(得分:0)
我发现最大Area值实际上是一个Decimal(16,10),这可以解释这一点。不知道我怎么想念它!