Cause: java.sql.SQLException: Zero date value prohibited 异常解决方法

本文详细介绍了MySQL JDBC连接字符串中的zeroDateTimeBehavior属性,该属性用于处理 DATETIME 值全为0的情况。当值为'exception'时,会抛出SQLException异常;设为'convertToNull',则数据库返回null代替无效日期;设为'round',日期会被转换为0001-01-01。了解此属性有助于避免日期时间处理中的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

jdbc:mysql://yourserver:3306/yourdatabase?zeroDateTimeBehavior=convertToNull

大致的意思:zeroDateTimeBehavior 属性,当遇到DATETIME值完全由0组成时,最终的有效值可以设置为,异常(exception),一个近似值(round),或将这个值转换为null(convertToNull)。
也就是说
1. zeroDateTimeBehavior 设置为 exception(不设置时是默认),(设置这个属性会抛出一个SQLException异常,其SQLSate码为S1009)
2. zeroDateTimeBehavior 设置为 convertToNull ,数据库会返回 null来代替 0000-00-00 这样的无效日期
3. zeroDateTimeBehavior 设置为 round,数据库 会将日期转换为0001-01-01 返回。

版权声明:本文为CSDN博主「-停泊」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/zgz15515397650/article/details/98042271

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值