Heim >Datenbank >MySQL-Tutorial >Warum gibt SimpleDateFormat.parse ein anderes Format als das angegebene zurück?

Warum gibt SimpleDateFormat.parse ein anderes Format als das angegebene zurück?

Susan Sarandon
Susan SarandonOriginal
2024-10-27 16:10:021027Durchsuche

 Why Does SimpleDateFormat.parse Return a Different Format Than Specified?

SimpleDateFormatter.parse gibt eine Ausgabe in einem anderen Format als dem angegebenen aus

Diese Frage stellt sich, wenn versucht wird, einen UNIX-Zeitstempel in ein Datum mit einem bestimmten Wert umzuwandeln Formatieren mit SimpleDateFormat. Trotz der Einstellung des gewünschten Formats erscheint das sdf.parse-Ergebnis in einem anderen Format.

Lösung:

Um dieses Problem zu beheben, wird empfohlen, die Übergabe von Datumsangaben als zu vermeiden Zeichenfolgen in eine MySQL-Datenbank. Stattdessen ist es sicherer und präziser, Datumsobjekte zu übergeben, insbesondere Instanzen aus der Java-API für Datum und Uhrzeit (java.time). In diesem Fall ist ein LocalDateTime-Objekt geeignet:

<code class="java">String ep = "a1527069600";
long epoch = Long.parseLong(ep.substring(1));
Instant inst = Instant.ofEpochSecond(epoch);
LocalDateTime ldt = inst.atZone(ZoneId.of("Asia/Calcutta")).toLocalDateTime();</code>

Für die Datenbankspeicherung stellt LocalDateTime die Datumszeit im Format „2018-05-23T15:30“ dar.

Um die LocalDateTime in einem zu speichern MySQL-Datenbank:

<code class="java">PreparedStatement ps = myDatabaseConnection.prepareStatement(
                "insert into my_table (my_date_time) values (?)");
    ps.setObject(1, ldt);</code>

Alternative für UTC-Werte:

Wenn die Datenbankwerte in UTC (Universal Time Coordinated) gespeichert werden sollen, verwenden Sie die folgende Konvertierung:

<code class="java">LocalDateTime ldt = inst.atOffset(ZoneOffset.UTC).toLocalDateTime();</code>

Vorteile der Verwendung von java.time:

  • Entfernt Formatierungsprobleme
  • Bietet eine moderne und umfassende Datums- und Uhrzeit-API

Das obige ist der detaillierte Inhalt vonWarum gibt SimpleDateFormat.parse ein anderes Format als das angegebene zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn