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

时间:2016-11-11 14:26:23

标签: java date timestamp simpledateformat

我正在尝试在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");

我哪里出错。

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

2 个答案:

答案 0 :(得分:2)

TL;博士

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

详细

Answer by Just another Java programmer是正确的。

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

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

LocalDate

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类。搜索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.DateCalendar和& SimpleDateFormat

现在位于Joda-Timemaintenance mode项目建议迁移到java.time。

要了解详情,请参阅Oracle Tutorial。并搜索Stack Overflow以获取许多示例和解释。规范是JSR 310

从哪里获取java.time类?

ThreeTen-Extra项目使用其他类扩展java.time。该项目是未来可能添加到java.time的试验场。您可以在此处找到一些有用的课程,例如IntervalYearWeekYearQuartermore

答案 1 :(得分:1)

您的日期格式不匹配。

最好是使用PreparedStatement,这样你就不会依赖字符串转换。