使用T-SQL和Microsoft SQL Server,我想指定十进制数字的数量,当我做2个整数之间的除法,如:
select 1/3
它当前返回0。我想让它返回(0,33)
喜欢的东西:
select round(1/3, -2)
但这行不通。我怎样才能达到预期的结果?
使用T-SQL和Microsoft SQL Server,我想指定十进制数字的数量,当我做2个整数之间的除法,如:
select 1/3
它当前返回0。我想让它返回(0,33)
喜欢的东西:
select round(1/3, -2)
但这行不通。我怎样才能达到预期的结果?
当前回答
如果你来这里(就像我一样)寻找整数值的解决方案,以下是答案:
CAST(9/2 AS UNSIGNED)
返回5
其他回答
没有必要对它们都施法。除法的结果数据类型总是具有较高数据类型优先级的数据类型。因此,解决办法必须是:
SELECT CAST(1 AS float) / 3
or
SELECT 1 / CAST(3 AS float)
看起来这个技巧在SQL Server中有效,而且更短(基于之前的回答)
SELECT 1.0*MyInt1/MyInt2
Or:
SELECT (1.0*MyInt1)/MyInt2
如果您正在寻找一个常数,来自stb和xiowl的建议是很好的。如果你需要使用现有的整数字段或参数,你可以先将它们转换为浮点数:
SELECT CAST(1 AS float) / CAST(3 AS float)
or
SELECT CAST(MyIntField1 AS float) / CAST(MyIntField2 AS float)
因为SQL Server执行整数除法。试试这个:
select 1 * 1.0 / 3
当您将整数作为参数传递时,这很有帮助。
select x * 1.0 / y
use
select 1/3.0
这个就行了。