有没有办法检查隐式转换的结果数据类型是什么?或者我只是必须根据加入算术运算的数据类型来了解它?
declare @i as int
set @i = 3
select @i / 9.0 as returning_numeric
答案 0 :(得分:3)
表达式的结果是numeric (17,6)
。要看到这个
DECLARE @i INT, @v SQL_VARIANT
SET @i = 3
SET @v = @i / 9.0
SELECT
CAST(SQL_VARIANT_PROPERTY(@v, 'BaseType') AS VARCHAR(30)) AS BaseType,
CAST(SQL_VARIANT_PROPERTY(@v, 'Precision') AS INT) AS Precision,
CAST(SQL_VARIANT_PROPERTY(@v, 'Scale') AS INT) AS Scale
返回
BaseType Precision Scale
---------- ----------- -----------
numeric 17 6
SELECT SQL_VARIANT_PROPERTY(9.0, 'BaseType'),
SQL_VARIANT_PROPERTY(9.0, 'Precision'),
SQL_VARIANT_PROPERTY(9.0, 'Scale')
因此,文字9.0
被视为numeric(2,1)
(可从上面的查询中看到)
@i
为numeric(10,0)
(根据Mikael's answer)
管理numeric(10,0)
/ numeric(2,1)
为何numeric (17,6)
are covered here
Operation: e1 / e2
Result precision: p1 - s1 + s2 + max(6, s1 + p2 + 1)
Result scale: max(6, s1 + p2 + 1)
用相应的值代替
10 - 0 + 1 + max(6, 0 + 2 + 1) = 17
max(6, 0 + 2 + 1) = 6
答案 1 :(得分:2)
这里完成的隐式转换是@i
到数字(10,0)。您可以修改您的陈述并查看执行计划。
declare @i int
set @i = 3
select @i / 9.0
from (select 1) as x(x)
从执行计划中提取
<ScalarOperator ScalarString="CONVERT_IMPLICIT(numeric(10,0),[@i],0)/(9.0)">
但是,结果数据类型为numeric(17,6)
,正如Martin在答案中所示,并且未在执行计划中显示。