Oracle约会到Java日期

时间:2011-08-24 05:55:19

标签: java oracle date

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

我正在使用这个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。感谢。

2 个答案:

答案 0 :(得分:14)

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

h代表“上午/下午(1-12)”和H代表“一天中的小时(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");

答案 1 :(得分:1)

TL;博士

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

详细

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

java.time

此外,您正在使用现在遗留下来的可怕的旧日期时间类,取而代之的是java.time类。

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

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及更高版本中。这些类取代了麻烦的旧legacy日期时间类,例如java.util.DateCalendar和& SimpleDateFormat

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

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

如果JDBC driver符合JDBC 4.2或更高版本,您可以直接与数据库交换 java.time 对象。不需要字符串或java.sql。* classes。

从哪里获取java.time类?

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