sql >> Databáze >  >> RDS >> Mysql

Jak extrahovat datum a čas z String Timestamp v Javě

Použijte java.text.SimpleDateFormat a java.util.TimeZone

Ve kterém časovém pásmu je řetězec data? Nahraďte níže uvedené UTC časové pásmo s tímto časovým pásmem

SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
sdf.setTimeZone(TimeZone.getTimeZone("UTC"));
Date date = sdf.parse("2014-02-15 05:18:08");

SimpleDateFormat sdf2 = new SimpleDateFormat("dd-MM-yyyy hh:mm:ss a");
sdf2.setTimeZone(TimeZone.getTimeZone("IST"));
String dateStr = sdf2.format(date); // Output: 15-02-2014 10:48:08 AM

Poznámka: V jakém formátu je ve vašem vstupním řetězci hodina (24 hodin/12 hodin)? Výše uvedený příklad předpokládá, že je ve 24hodinovém formátu, protože ve vstupním řetězci nejsou žádné informace AM/PM.

Pokud je vstupní řetězec také ve 12hodinovém formátu, měl by váš vstupní řetězec obsahovat informace o AM/PM také jako 2014-02-15 05:18:08 PM . V takovém případě upravte sdf na new SimpleDateFormat("yyyy-MM-dd hh:mm:ss a")

=========================Upraveno: ======================

Chcete-li odpovědět na vaši další otázku v komentáři "Jak extrahovat datum a čas samostatně"...

SimpleDateFormat sdfDate = new SimpleDateFormat("dd-MM-yyyy");
sdfDate.setTimeZone(java.util.TimeZone.getTimeZone("IST"));

SimpleDateFormat sdfTime = new SimpleDateFormat("hh:mm:ss a");
sdfTime.setTimeZone(java.util.TimeZone.getTimeZone("IST"));

String dateStr = sdfDate.format(date);
String timeStr = sdfTime.format(date);


  1. Jak rozdělit transakce pouze pro čtení a čtení a zápis pomocí JPA a Hibernate

  2. EclipseLink selže při načítání skalární booleovské hodnoty

  3. PostgreSQL předává data z rekurzivního CTE do funkce

  4. Jak nastavit regex v dotazu MySQL