Ist java.sql.Timestamp Zeitzonenspezifisch?
Hintergrund:
JDBCs setTimestamp( int parameterIndex, Timestamp x)-Methode weist einer Datenbankspalte einen Zeitstempel zu, ohne den explizit anzugeben Zeitzone. Dies wirft die Frage auf: Enthält Timestamp Zeitzoneninformationen?
Antwort:
Nein, java.sql.Timestamp enthält von Natur aus keine Zeitzoneninformationen.
Erklärung:
Beim Aufruf von setTimestamp(...), Der JDBC-Treiber verlässt sich auf die Zeitzone der virtuellen Maschine, auf der die Anwendung ausgeführt wird, um das Datum und die Uhrzeit für die Speicherung zu bestimmen. Dies bedeutet, dass der gespeicherte Wert keine Zeitzoneninformationen behält.
Beispiel:
Stellen Sie sich das folgende Szenario vor:
In diesem Fall konvertiert der Treiber die UTC-Zeit in IST (basierend auf der Zeitzone der virtuellen Maschine) und speichert sie als „20121225 12:00“. :00" in der Datenbank.
Speichern von Zeitstempeln im Einzelnen Zeitzonen:
Um Zeitstempel in einer bestimmten Zeitzone zu speichern, verwenden Sie die Methode setTimestamp(int parameterIndex, Timestamp x, Calendar cal). Geben Sie ein Kalenderobjekt mit der gewünschten Zeitzone an, um sicherzustellen, dass der Zeitstempel entsprechend gespeichert wird.
Zusätzliche Überlegungen:
Das obige ist der detaillierte Inhalt vonSpeichert „java.sql.Timestamp' Zeitzoneninformationen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!