Oracle约会到Java日期

SimpleDateFormat用于解析Oracle日期的内容是什么?

我正在使用这个SimpleDateFormat。

SimpleDateFormat dateFormat = new SimpleDateFormat(“yyyy / mm / dd hh:mm:ss.sss”);

它给出了这个例外。

java.text.ParseException:Unparseable date:“2011-08-19 06:11:03.0”

请告诉我要使用的SimpleDateFormat。 谢谢。

您应该使用此模式"yyyy-MM-dd HH:mm:ss.S"而不是"yyyy/mm/dd hh:mm:ss.sss"

“上午/下午(1-12)小时”和“日间小时(0-23)”的小时
看到这里: SimpleDateFormat

 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.S"); Date date = dateFormat.parse("2011-08-19 06:11:03.0"); 

TL;博士

 LocalDateTime.parse( "2011-08-19 06:11:03.0".replace( " " , "T" ) ) 

细节

您的输入字符串与格式设置模式不匹配。 您的模式具有斜杠字符,其中您的数据具有连字符。

java.time

此外,您正在使用可怕的旧日期时间类,这些类现在是遗留的,由java.time类取代。

您的输入字符串几乎符合日期时间格式的ISO 8601标准。 用T替换中间的空格。

 String input = "2011-08-19 06:11:03.0".replace( " " , "T" ) ; 

您的输入缺少任何时区指示符或与UTC的偏移量。 所以我们解析为LocalDateTime ,对于缺少任何区域/偏移概念的对象。

 LocalDateTime ldt = LocalDateTime.parse( input ) ; 

要以标准格式生成字符串,请调用toString

 String output = ldt.toString() ; 

如果此输入用于特定时区,请进行分配。

 ZoneId z = ZoneId.of( "Africa/Tunis" ) ; ZonedDateTime zdt = ldt.atZone( z ) ; 

关于java.time

java.time框架内置于Java 8及更高版本中。 这些类取代了麻烦的旧遗留日期时间类,如java.util.DateCalendarSimpleDateFormat

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

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

使用符合JDBC 4.2或更高版本的JDBC驱动程序 ,您可以直接与数据库交换java.time对象。 不需要字符串或java.sql。*类。

从哪里获取java.time类?

  • Java SE 8Java SE 9及更高版本
    • 内置。
    • 带有捆绑实现的标准Java API的一部分。
    • Java 9增加了一些小function和修复。
  • Java SE 6Java SE 7
    • 许多java.timefunction都被反向移植到ThreeTen-Backport中的 Java 6和7。
  • Android的
    • 更高版本的Android捆绑java.time类的实现。
    • 对于早期的Android, ThreeTenABP项目采用ThreeTen-Backport (如上所述)。 请参见如何使用ThreeTenABP ….

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