mysql查表的时候报错:java.sql.SQLException: Value '0000-00-00 00:00:00' can not be represented as java.sql.Timest
🌴问题描述:
在web项目中读取mysql中的数据的时候,发生了报错🌴原因分析:
原因:因为数据库中有一些字段为null,无法进行正常转换:
上面字段那种,我的outtime字段类型为timestamp类型,不为空,默认值为000-00-00 00:00:00,所以无法进行转换,所以要进行处理一下。
🚀解决方案:
只需在连接数据库的url地址中拼接一个&zeroDateTimeBehavior=convertToNull
,就行转换即可解决。
修改之前的url:
url=jdbc:mysql://localhost:3306/e?serverTimezone=UTC
修改之后的url:
url=jdbc:mysql://localhost:3306/e?serverTimezone=UTC&zeroDateTimeBehavior=convertToNull
🚀总结:
为什么要加&zeroDateTimeBehavior=convertToNull
?
因为JAVA连接MySQL数据 库,在操作各项值均为为0(或者有0 不正确的数据??)的timestamp日期为000-00-00 00:00:00
类型时不能正确处理 ,而是默认抛出一个异 常,比如所见的:
java.sql.SQLException: Cannot convert value '0000-00-00 00:00:00' from column XX to TIMESTAMP
。
举个例子:
你的方法中要传入来自页面的日期参数值 ,按照正常的做法,比如日期值为2016-10-11,但是由于误操作,传入了0000-00-00,并没有设置正确的数据,那么这时默认抛出java.sql.SQLException异常。
所以设置zeroDateTimeBehavior=convertToNull
(英文单词为:zero Date Time Behavior = convert To Null) 字面意思为零日期时间行为转换为空,把日期转换为null代替异常处理。即这类操作情况的处理策略,有一下3种:
- exception(不指定,则默认)---->默认抛出异常,
- convertToNull------->转化为null
- round------->替换成最近的日期即XXXX-01-01
这个在指定管理的数据库连接属性文件(jdbc.properties )jdbc 的URL常用到
jdbc.url=jdbc:mysql://localhost:3306/databaseName?zeroDateTimeBehavior=convertToNul l