当前位置:   article > 正文

Java查询 MySQL:float 类型字段默认科学计数问题解决_spring的mysql查询自动转科学计数

spring的mysql查询自动转科学计数

问题描述:
SpringBoot中,通过mybatis查询MySQL,其中,一个字段是float类型,Java对应类型为Float类型
这边,对该类型toString进行拼接的时候,变成了科学计数方式。
入下图:
在这里插入图片描述
网上给的方式是从Java层面解决,代码如下(不推荐):

    // 方法一:NumberFormat
    private static String big(float d) {
        NumberFormat nf = NumberFormat.getInstance();
        // 是否以逗号隔开, 默认true以逗号隔开,如[123,456,789.128]
        nf.setGroupingUsed(false);
        // 结果未做任何处理
        return nf.format(d);
    }

    //方法二: BigDecimal
    private static String big2(float d) {
        BigDecimal d1 = new BigDecimal(Double.toString(d));
        BigDecimal d2 = new BigDecimal(Integer.toString(1));
        // 四舍五入,保留2位小数
        return d1.divide(d2,2,BigDecimal.ROUND_HALF_UP).toString();
    }
    
	//方法三: BigDecimal
    public static String NonScientificNotation(String num)
    {
        Pattern pattern = Pattern.compile("-?[0-9]*.[0-9]*E[0-9]*");
        Matcher match   = null;
        match = pattern.matcher(num);
        if(match.matches())
        {
            BigDecimal decimal = new BigDecimal(num);
            num = decimal.toPlainString();
        }
        return num;
    }
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30

上述三个方法,本质,还是先把查出的float转成了科学计数,然后,在进行还原
产生的问题就是,精度不准确。

我的解决办法:
从MySQL库中,查询的时候,就把该字段转成char类型,对应Java里面就已经是string类型了。
此时,拼接,就不会出现科学计数的问题。
在这里插入图片描述
解决代码:
关键在于CONVERT(dm.ALL_FILE_SIZE,CHAR)函数的使用

    SELECT CONVERT(dm.ALL_FILE_SIZE,CHAR) FILE_SIZE_STR FROM data_monitor dm
  • 1
声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/688309
推荐阅读
相关标签
  

闽ICP备14008679号