height
在我的 SQL Server 表中,列是整数类型。我想做一个除法,并在我的查询中将结果作为十进制:
Select (height/10) as HeightDecimal
如何转换以使HeightDecimal
不再是整数?谢谢。
height
在我的 SQL Server 表中,列是整数类型。我想做一个除法,并在我的查询中将结果作为十进制:
Select (height/10) as HeightDecimal
如何转换以使HeightDecimal
不再是整数?谢谢。
SELECT height/10.0 AS HeightDecimal FROM dbo.whatever;
如果您想要特定的精度刻度,请这样说:
SELECT CONVERT(DECIMAL(16,4), height/10.0) AS HeightDecimal
FROM dbo.whatever;
SELECT CAST(height AS DECIMAL(18,0)) / 10
编辑: 这是如何在引擎盖下工作的?
结果类型与两个参数的类型相同,或者,如果它们不同,则由数据类型优先级表确定。因此,您可以将任一参数转换为非整数。
现在DECIMAL(18,0)
,或者您可以等效地写成DECIMAL
,仍然是一种整数类型,因为默认0
的小数位数表示“小数点右侧没有数字”。因此,在不同的情况下,对它的强制转换可能对四舍五入很有效——这与我们试图完成的相反。
但是,十进制对所有事物都有自己的规则。它们通常是非整数,但总是精确的数字。我们强制发生的 DECIMAL 除法的结果类型在我们的例子中被特别确定为 DECIMAL(29,11)。因此,除法的结果将舍入到 11 位,这与除以 10 无关,但除以 3 时,舍入变得可观察到。您可以通过操纵左侧操作数的比例来控制舍入量。您还可以通过在整个表达式周围放置另一个 ROUND 或 CAST 操作来进行更多但不能更少的舍入。
相同的机制在公认的答案中支配着更简单和更好的解决方案:
SELECT height / 10.0
在这种情况下,除数DECIMAL(3,1)
的类型是 ,结果的类型是DECIMAL(17,6)
。尝试除以 3 并观察四舍五入的差异。
如果您只是讨厌所有关于精度和比例的讨论,并且只是希望 SQL Server 从某个时候开始以良好的旧双精度浮点算术执行所有计算,那么您也可以强制执行此操作:
SELECT height / CAST(10 AS FLOAT(53))
或等价地
SELECT height / CAST (10 AS FLOAT)
您可以将高度转换为小数:
select cast(@height as decimal(10, 5))/10 as heightdecimal
或者您在除以的值中放置一个小数点:
declare @height int
set @height = 1023
select @height/10.0 as heightdecimal
请参阅sqlfiddle示例
select cast (height as decimal)/10 as HeightDecimal
declare @xx int
set @xx = 3
select @xx
select @xx * 2 -- yields another integer
select @xx/1 -- same
select @xx/1.0 --yields 6 decimal places
select @xx/1.00 -- 6
select @xx * 1.0 -- 1 decimal place - victory
select @xx * 1.00 -- 2 places - hooray
另外 _ 将一个 int 插入到 temp_table 中,比如 decimal(10,3) _ 工作正常。