SQL查询中整数向上取整的技术问询:如何实现仅对最后两位无条件向上取整的单查询方案?
解决方案:无条件向上取整到最近整百的单条SQL语句
没问题,我来帮你搞定这个需求!你遇到的问题主要是原语句在数值本身是整百时会多加上100,而ROUND函数是四舍五入逻辑,不符合你无条件向上取整的要求。
正确的单条查询写法
你可以使用CEILING()函数来实现这个需求,它的作用就是返回大于等于指定数值的最小整数,搭配简单的数值转换就能完美满足你的要求:
DECLARE @number int; SET @number = 918740; SELECT CEILING(@number / 100.0) * 100 AS RoundedUpToHundred;
测试验证
我们来验证几个核心场景:
- 当
@number = 918750时:918750 / 100.0 = 9187.5,CEILING(9187.5)返回9188,乘以100后得到918800,符合预期。 - 当
@number = 918800时:918800 / 100.0 = 9188.0,CEILING(9188.0)返回9188,乘以100后还是918800,保持整百数不变。 - 当
@number = 918740时:918740 / 100.0 = 9187.4,CEILING(9187.4)返回9188,乘以100后得到918800,实现了无条件向上取整。
关键注意点
这里一定要用100.0而不是100做除法——因为SQL Server中整数除以整数会执行截断式的整数除法,比如918740 / 100会得到9187而不是9187.4,这样CEILING就起不到向上取整的作用了。用100.0会触发浮点数除法,保留小数部分,才能让CEILING正确工作。
内容的提问来源于stack exchange,提问作者lass




