You need to enable JavaScript to run this app.
最新活动
大模型
产品
解决方案
定价
生态与合作
支持与服务
开发者
了解我们

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.5CEILING(9187.5)返回9188,乘以100后得到918800,符合预期。
  • @number = 918800时:918800 / 100.0 = 9188.0CEILING(9188.0)返回9188,乘以100后还是918800,保持整百数不变。
  • @number = 918740时:918740 / 100.0 = 9187.4CEILING(9187.4)返回9188,乘以100后得到918800,实现了无条件向上取整。

关键注意点

这里一定要用100.0而不是100做除法——因为SQL Server中整数除以整数会执行截断式的整数除法,比如918740 / 100会得到9187而不是9187.4,这样CEILING就起不到向上取整的作用了。用100.0会触发浮点数除法,保留小数部分,才能让CEILING正确工作。

内容的提问来源于stack exchange,提问作者lass

火山引擎 最新活动