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

相关文章

SELECT a.*,b.dp_name,c.pa_name,fm_name=(CASE WHEN a.fm_n...
if not exists(select name from syscolumns where name=&am...
select a.*,pano=a.pa_no,b.pa_name,f.dp_name,e.fw_state_n...
要在 SQL Server 2019 中设置定时自动重启,可以使用 Window...
您收到的错误消息表明数据库 'EastRiver' 的...
首先我需要查询出需要使用SQL Server Profiler跟踪的数据库标...