加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

SQL中的重要数字

发布时间:2020-12-12 16:33:32 所属栏目:MsSql教程 来源:网络整理
导读:我想在SQL中能够将数字转化为n个重要数字.所以: 123.456 rounded to 2sf would give 1200.00123 rounded to 2sf would give 0.0012 我知道ROUND()函数,它返回到n个小数位,而不是有效数字. 解决方法 选择round(@ number,@ sf-1- floor(log10(abs(@number))))
我想在SQL中能够将数字转化为n个重要数字.所以:
123.456 rounded to 2sf would give 120
0.00123 rounded to 2sf would give 0.0012

我知道ROUND()函数,它返回到n个小数位,而不是有效数字.

解决方法

选择round(@ number,@ sf-1- floor(log10(abs(@number))))应该做的伎俩!

成功测试了你的两个例子.

编辑:在@ number = 0上调用此函数将不起作用.在使用此代码之前,您应该添加一个测试.

create function sfround(@number float,@sf int) returns float as
begin
    declare @r float
    select @r = case when @number = 0 then 0 else round(@number,@sf -1-floor(log10(abs(@number )))) end
    return (@r)
end

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读