gpt4 book ai didi

Java:将日期值保存到数据库时出错(Simpledateformat)

转载 作者:行者123 更新时间:2023-11-29 04:37:45 25 4
gpt4 key购买 nike

我正在尝试在数据库中保存日期,但出现以下错误。我很困惑,因为我发送相同的格式但仍然抛出异常:

java.lang.IllegalArgumentException: Timestamp format must be yyyy-mm-dd hh:mm:ss[.fffffffff]

如果我在 SQL Developer 中以下面的方式尝试它工作正常

to_date('01/01/1900', 'mm/dd/yyyy')

我尝试通过 java 执行以下操作

第一种方法

SimpleDateFormat format1 = new SimpleDateFormat("dd/MM/yyyy HH:mm:ss");
Date myDate = format1.parse("01/01/1900 00:00:00");

第二种方法

SimpleDateFormat format1 = new SimpleDateFormat("dd/MM/yyyy");
Date myDate = format1.parse("01/01/1900");

我哪里错了。

P.S:在将其标记为重复并阻止人们回答问题之前,请理解我已经尝试了一些东西并遇到了错误。

最佳答案

tl;dr

myPreparedStatement.setObject(
… ,
LocalDate.parse(
"01/01/1900" ,
DateTimeFormatter.ofPattern( "dd/MM/uuuu" )
)
)

详情

Answer by Just another Java programmer是正确的。

此外,您不应该使用字符串来与数据库交流日期时间值。使用日期时间类。

现代方法是使用 java.time 类,取代麻烦的遗留日期时间类。

本地日期

LocalDate类表示没有时间和时区的纯日期值。

时区对于确定日期至关重要。对于任何给定时刻,日期在全局范围内因地区而异。例如,午夜后几分钟 Paris France是新的一天,但在Montréal Québec 中仍然是“昨天” .

ZoneId z = ZoneId.of( "America/Montreal" );
LocalDate today = LocalDate.now( z );

您可以直接从标准 ISO 8601 格式的字符串中解析。

LocalDate localDate = LocalDate.parse( "2016-01-23" );

或指定每个部分。

LocalDate localDate = LocalDate.of( 2016, Month.JANUARY , 23 );

要解析其他格式,请使用 DateTimeFormatter类(class)。在 Stack Overflow 中搜索许多示例。

数据库

如果您的 JDBC driver符合 JDBC 4.2或更高版本,它应该能够使用 PreparedStatement::setObject 传递 java.time 类型并使用 ResultSet::getObject 获取.

myPreparedStatement.setObject( … , localDate );

……或者……

myPreparedStatement.setObject( … , localDate , JDBCType.DATE );

如果您的驱动程序未启用,请回退到使用 java.sql.Date .这个笨拙的类假装代表一个仅限日期的值(但实际上有一个时间组件设置为午夜,我们应该忽略它)。要与 java.time 相互转换,请查看添加到旧类的新方法。

java.sql.Date sqlDate = java.sql.Date.valueOf( localDate );

然后转向另一个方向。

LocalDate localDate = sqlDate.toLocalDate();

传递给 PreparedStatement::setDate .

myPreparedStatement.setDate( … , sqlDate );

关于java.time

java.time框架内置于 Java 8 及更高版本中。这些类取代了麻烦的旧类 legacy日期时间类,例如 java.util.Date , Calendar , & SimpleDateFormat .

Joda-Time项目,现在在maintenance mode , 建议迁移到 java.time。

要了解更多信息,请参阅 Oracle Tutorial .并在 Stack Overflow 中搜索许多示例和解释。规范为 JSR 310 .

从哪里获得 java.time 类?

ThreeTen-Extra项目用附加类扩展 java.time。该项目是 future 可能添加到 java.time 的试验场。您可能会在这里找到一些有用的类,例如 Interval , YearWeek , YearQuarter , 和 more .

关于Java:将日期值保存到数据库时出错(Simpledateformat),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40550044/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com