背景
运营提供了一版数据,并且导入到数据库里了,但是测试同学测的时候发现要统计的页面显示的数值,总是和数据库中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字段中的逗号都替换为空字符串