写点什么

YashanDB|JDBC getString 取 DATE 字段不带时分秒? 两个方法解决!

作者:数据库砖家
  • 2025-05-13
    广东
  • 本文字数:503 字

    阅读完需:约 2 分钟

【问题描述】

在使用 YashanDB JDBC 驱动查询 DATE 类型字段时,如果直接使用:

resultSet.getString(1);
复制代码

返回结果只包含日期(如 2024-05-01),不包含时分秒

【示例现象】

数据库中原始字段值为:

2024-05-01 15:30:00
复制代码

但 getString() 返回结果却是:

2024-05-01
复制代码

这会导致部分依赖时间精度的业务逻辑异常。

【影响范围】

适用于 所有 YashanDB JDBC 驱动版本

【问题原因】

YashanDB JDBC 驱动在 DATE 类型字段解析时,getString() 默认只取日期部分,不自动附带时分秒。

这是驱动实现细节所致,并非数据库数据缺失,而是驱动层对 DATE 类型做了默认“轻量格式化”。

【解决方法】

方式一:改用 getTimestamp()方法(推荐)

String ts = resultSet.getTimestamp(1).toString();
复制代码

这样可以完整获取日期 + 时间,例如:

2024-05-01 15:30:00.0
复制代码

方式二:在连接串中设置参数

在 JDBC URL 中添加:

mapDateToTimestamp=true
复制代码

完整示例:

String url = "jdbc:yashandb://127.0.0.1:8080/dbname?mapDateToTimestamp=true";
复制代码

启用后,即使使用 getString() 也会返回完整的日期+时间字符串。

【推荐做法总结】

【风险提示】

若业务代码依赖 getString() 且未添加参数,可能导致日期字段截断,建议统一加参数或替换调用方式。

用户头像

还未添加个人签名 2025-04-09 加入

还未添加个人简介

评论

发布
暂无评论
YashanDB|JDBC getString 取 DATE 字段不带时分秒?两个方法解决!_数据库_数据库砖家_InfoQ写作社区