对 DATETIME 值 0000-00-00 00:00:00 的 JDBC 空处理
MySQL 处理 DATETIME 值 0000-00- 00 00:00:00 作为“准空”值,以及尝试从 JDBC 连接检索字符串等值可能会导致异常。
要处理此问题,请考虑使用以下解决方案:
选项 1:转换为 CHAR
您可以在 SQL 中将 DATETIME 列显式转换为 CHAR查询:
SELECT CAST(add_date AS CHAR) AS add_date
这将返回原始 DATETIME 字符串,而不将其转换为特定数据类型。
选项 2:使用 JDBC 配置
或者,您可以使用 ZeroDateTimeBehavior 配置 JDBC URL参数:
jdbc:mysql://yourserver:3306/yourdatabase?zeroDateTimeBehavior=convertToNull
使用此配置,DATETIME 值 0000-00-00 00:00:00 将在结果集中自动转换为 NULL。
zeroDateTimeBehavior 参数可以采用不同的值value:
请注意,此设置会影响数据库中的所有 DATETIME 列。
来源:
以上是如何使用 JDBC 处理 MySQL 的 0000-00-00 00:00:00 DATETIME 值?的详细内容。更多信息请关注PHP中文网其他相关文章!