首页 > 数据库 > mysql教程 > 如何使用 JDBC 处理 MySQL 的 0000-00-00 00:00:00 DATETIME 值?

如何使用 JDBC 处理 MySQL 的 0000-00-00 00:00:00 DATETIME 值?

Barbara Streisand
发布: 2025-01-02 13:05:38
原创
642 人浏览过

How to Handle MySQL's 0000-00-00 00:00:00 DATETIME Values with JDBC?

对 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:

  • 异常: 抛出异常(默认)
  • convertToNull: 将值转换为 NULL
  • round: 将值四舍五入到最接近的值(0001-01-01)

请注意,此设置会影响数据库中的所有 DATETIME 列。

来源:

  • MySQL手册: https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-configuration-properties.html

以上是如何使用 JDBC 处理 MySQL 的 0000-00-00 00:00:00 DATETIME 值?的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板