有的时候数字超长,无论是数据库进行操作还是Java代码进行操作,都会变为科学计数法。
现在有一个string类型的字段code,每新增一条数据,code+1。因为需要的code很长,所以定义为了string类型。
用MySQL数据库自带的函数MAX(code)+1得到的值为科学计数法的值。需要的是正常的值。
尝试了将code转为double类型+1后再转为string,发现还是变成了科学计数法。
查询资料最终将code转为Big Decimal类型+1后再转为string类型。
public class Test {
public static void main(String[] args) {
String code = "1001000200010001";
System.out.println(code); //1001000200010001
Double codeDouble = Double.parseDouble(code) + 1;
System.out.println(codeDouble); //1.001000200010002E15
code = new BigDecimal(code ).add(new BigDecimal(1)).toString();
System.out.println(code); //1001000200010002
}
}