作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
有没有办法检查隐式转换的结果数据类型是什么?还是只需要根据加入算术运算的数据类型就知道了?
declare @i as int
set @i = 3
select @i / 9.0 as returning_numeric
最佳答案
表达式的结果是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
关于SQL 服务器 : Is there a way to check what is the resulting data type of implicit conversion?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5606689/
我是一名优秀的程序员,十分优秀!