关于com.mysql.cj.exceptions.WrongArgumentException: ‘�‘ is not......的一些探讨和解决办法

关于com.mysql.cj.exceptions.WrongArgumentException: '�' is not a valid numeric or approximate numeric value问题的探讨和解决办法

前言

公司需要开发一套从Huawei Research获取心率数据并进行HRV计算,那么在计算的过程中我们会针对数据进行一部分筛查,然后才开始计算,计算完插入数据库。

踩坑过程

一、一开始找到别的博文是说xml文件配置那里有&,因为在xml文件中不能直接使用&,会被转义为上面的&amp ;(写一起就会被转义成&,所以空了一格),当直接把数据从xml中拿出来时,仍然保持转义状态。结果发现并不是,然后又看到url里面有时区的配置就自动忽略了。
二、因为神似mysql没有配置时区的错误,发现yml写了时区,mysql本地并没有配置时区,去配置了时区,结果还是不行。
三、还有博文说是因为驱动和mysql版本不同,需要对应版本,结果也试了还是不行。

问题原因

作为一个Java小菜鸟忽略了在筛查的过程中是会可能有除数或者被除数为空的情况。整数和字符常量被0除将会产生一个异常,并且

浮点数被0除将会得到无穷大或者Nan

没错,这就是问题所在。下面举栗说一下一些常见问题:

double i=0;
System.out.println(i/0);  // NaN

System.out.println(1/i);  // Infinity

System.out.println(i/i);  // NaN

System.out.println(1/0); // 抛出异常java.lang.ArithmeticException: / by zero

从上面可以看到:一个为零的浮点类型的数据在做除数时,如果被除数是整型,则结果为Infinity,也就是一个无穷数;

如果被除数是为零的浮点类型,则无论除数是整型还是浮点类型的零,结果都是NaN。

当一个整数除以整数类型的零时,则会抛出异常

float 类型的 0 在除法中不会用准确的0而是非常接近0的小数来表示。

NaN,意思是not an number,即”不是数字”。Java虚拟机在处理浮点数运算时,不会抛出任何运行时异常,当一个操作产生溢出时,将会使用有符号的无穷大(Infinity)来表示,如果某个操作结果没有明确的数学定义的话,将会使用 NaN 值来表示,所有使用 NaN 值作为操作数的算术操作,结果都返回NaN。Java 中的 Double 和 Float 中都有isNaN函数,判断一个数是不是NaN,其实现都是通过 v != v 的方式,因为 NaN 是唯一与自己不相等的值,NaN 与任何值都不相等。

更多栗子可以看这个博文

解决办法

使用Double.isNaN(double x)来判断,返回的是布尔类型。Double表示判断类型
当判断A为Nan时,就使用别的东西替换或者直接不插入。

// 举个栗子
if(!Double.isNaN(A)){
	RMSSD_MinData[i] = Math.sqrt(rmssd / len);
}else{
    RMSSD_MinData[i] = 1.0000;
}

总结:程序做计算的时候,一定要注意除数和被除数是否会有是0的情况。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值