Heim > Datenbank > MySQL-Tutorial > Hauptteil

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

Susan Sarandon
Freigeben: 2024-10-27 16:10:02
Original
988 Leute haben es durchsucht

 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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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>
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage