SQL Server:有没有办法检查隐式转换的结果数据类型是什么?

时间:2011-04-09 17:40:19

标签: sql sql-server sql-server-2005 sql-server-2008 types

有没有办法检查隐式转换的结果数据类型是什么?或者我只是必须根据加入算术运算的数据类型来了解它?

declare @i as int
set @i = 3
select @i  / 9.0 as returning_numeric

2 个答案:

答案 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)(可从上面的查询中看到)

@inumeric(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在答案中所示,并且未在执行计划中显示。