繁体   English   中英

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

[英]Java: Error while saving date value to database(Simpledataformat)

我想在DB中保存日期,但我收到以下错误。 我很困惑,因为我发送相同的格式但仍然抛出异常:

java.lang.IllegalArgumentException:时间戳格式必须为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");

我哪里错了。

PS:请在将其标记为重复并阻止人们回答问题之前理解我已经尝试了一些并得到了错误。

TL;博士

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

细节

只是另一个Java程序员答案是正确的。

此外,您不应使用字符串来将日期时间值与数据库进行通信。 使用日期时间类。

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

LocalDate

LocalDate类表示没有时间且没有时区的仅日期值。

时区对于确定日期至关重要。 对于任何给定的时刻,日期在全球范围内因地区而异。 例如, 法国巴黎午夜过后几分钟是新的一天,而在魁北克蒙特利尔仍然是“昨天”。

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类。 搜索Stack Overflow有很多例子。

数据库

如果JDBC驱动程序符合JDBC 4.2或更高版本,则它应该能够使用PreparedStatement::setObject传递java.time类型,并使用ResultSet::getObject传递fetch。

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及更高版本中。 这些类取代了麻烦的旧遗留日期时间类,如java.util.DateCalendarSimpleDateFormat

现在处于维护模式Joda-Time项目建议迁移到java.time。

要了解更多信息,请参阅Oracle教程 并搜索Stack Overflow以获取许多示例和解释。 规范是JSR 310

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展了java.time。 该项目是未来可能添加到java.time的试验场。 您可以在这里找到一些有用的类,比如IntervalYearWeekYearQuarter ,和更多

您的日期模式不匹配。

更好的是使用PreparedStatement因此您永远不会依赖字符串转换。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM