赞
踩
问题描述:
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; }
上述三个方法,本质,还是先把查出的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
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。