mysql查表的时候报错:java.sql.SQLException: Value ‘0000-00-00 00:00:00‘ can not be represented as java.sql.T

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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值