簡體   English   中英

Oracle約會到Java日期

[英]Oracle date to Java date

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"

h為和“AM / PM(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");

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及更高版本中。 這些類取代了麻煩的舊遺留日期時間類,如java.util.DateCalendarSimpleDateFormat

現在處於維護模式Joda-Time項目建議遷移到java.time類。

要了解更多信息,請參閱Oracle教程 並搜索Stack Overflow以獲取許多示例和解釋。 規范是JSR 310

使用符合JDBC 4.2或更高版本的JDBC驅動程序 ,您可以直接與數據庫交換java.time對象。 不需要字符串或java.sql。*類。

從哪里獲取java.time類?

ThreeTen-Extra項目使用其他類擴展了java.time。 該項目是未來可能添加到java.time的試驗場。 您可以在這里找到一些有用的類,比如IntervalYearWeekYearQuarter ,和更多

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM