sql语句sum后的值总是对不上(科学计数法,replace函数)

背景

运营提供了一版数据,并且导入到数据库里了,但是测试同学测的时候发现要统计的页面显示的数值,总是和数据库中sum后的值对不上

原因

当时我自己陷入误区了,以为导入的数据不对呢,还比较了提供的那版数据excel和页面上的显示的数据,也一样啊。但是一到对比数据库,总是也对不上。再到后来,我就挑了一个量比较少的数据进行比对,最后才发现,数据库存的居然是科学计数法的形式。比如,123,2.2

进而导致sum之后的值是乱的,比如下图:

sum(change_money)之后的值,正确应该是8023.73

解决

由于这个科学计数法的形式暂时还不能变动,现仅单纯解决sum值的这个问题

使用replace函数,话不多说,上sql

select sum(replace(change_money,",","")) from t_test;

可以看出,结果是正确的

replace函数

replace(object,search,replace)

将object字段中出现的search全部替换为replace

本文就是将change_money字段中的逗号都替换为空字符串

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值