SQL Server:舍入十进制数并转换为int(在Select中)

前端之家收集整理的这篇文章主要介绍了SQL Server:舍入十进制数并转换为int(在Select中)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在Select中使用以下行返回带小数的数字,
例如33.33333.

如何在Select中对此进行舍入并转换为整数,以便我没有小数,例如在上面的例子中它应该返回33?

100 * AVG(CASE WHEN col2 = col3 THEN 1.0 ELSE 0.0 END) AS matchPercent

蒂姆,非常感谢你提供的任何帮助.

解决方法

您可以使用ROUND函数将值四舍五入为整数:
ROUND(INT,100 * AVG(CASE WHEN col2 = col3 THEN 1.0 ELSE 0.0 END),0) AS matchPercent

这将保留类型,例如圆形浮子将保持浮动.如果还需要返回int数据类型(或其他整数数据类型),还需要转换它:

CONVERT(INT,ROUND(INT,0)) AS matchPercent

猜你在找的MsSQL相关文章