So fügen Sie java.time-Typen wie LocalDate in/aus einer SQL-Datenbank wie H2 ein und holen sie ab
Die alte Art der Verwendung von PreparedStatement::setDate und ResultSet ::getDate funktioniert für den alten Typ java.sql.Date. Es ist jedoch besser, die Verwendung dieser problematischen alten Datums-/Uhrzeitklassen zu vermeiden. Verwenden Sie stattdessen die modernen java.time-Typen.
Es gibt zwei Wege zum Austausch von java.time-Objekten über JDBC:
JDBC 4.2-kompatible Treiber
Wenn Ihr JDBC-Treiber kompatibel ist Mit der JDBC 4.2-Spezifikation oder höher können Sie direkt mit den java.time-Objekten umgehen. Kompatible Treiber kennen die java.time-Typen und haben setObject/getObject-Methoden hinzugefügt, um sie zu verarbeiten.
Um Daten an die Datenbank zu senden, übergeben Sie einfach Ihr java.time-Objekt an PreparedStatement::setObject. Der Java-Typ Ihres übergebenen Arguments wird vom Treiber erkannt und in den entsprechenden SQL-Typ konvertiert. Ein Java LocalDate wird in einen SQL DATE-Typ konvertiert.
Um Daten aus der Datenbank abzurufen, rufen Sie ResultSet::getObject auf. Anstatt das resultierende Object-Objekt umzuwandeln, können wir ein zusätzliches Argument übergeben, die Klasse des Datentyps, den wir erwarten. Durch die Angabe der erwarteten Klasse erhalten wir eine von Ihrer IDE und Ihrem Compiler überprüfte und verifizierte Typsicherheit.
Ältere Treiber, vor JDBC 4.2
Wenn Ihr JDBC-Treiber noch nicht JDBC 4.2 oder entspricht Später müssen Sie dann Ihre java.time-Objekte kurz in den entsprechenden java.sql-Typ konvertieren oder umgekehrt. Achten Sie auf neue Konvertierungsmethoden, die zu den alten Klassen hinzugefügt wurden.
Hier ist eine vollständig funktionierende Beispiel-App, die zeigt, wie man LocalDate-Werte in eine H2-Datenbank einfügt und auswählt:
import java.sql.*; import java.time.LocalDate; import java.time.ZoneId; import java.util.UUID; public class App { public static void main ( String[] args ) { App app = new App ( ); app.doIt ( ); } private void doIt ( ) { try { Class.forName ( "org.h2.Driver" ); } catch ( ClassNotFoundException e ) { e.printStackTrace ( ); } try ( Connection conn = DriverManager.getConnection ( "jdbc:h2:mem:trash_me_db_" ) ; Statement stmt = conn.createStatement ( ) ; ) { String tableName = "test_"; String sql = "CREATE TABLE " + tableName + " (\n" + " id_ UUID DEFAULT random_uuid() PRIMARY KEY ,\n" + " date_ DATE NOT NULL\n" + ");"; stmt.execute ( sql ); // Insert row. sql = "INSERT INTO test_ ( date_ ) " + "VALUES (?) ;"; try ( PreparedStatement preparedStatement = conn.prepareStatement ( sql ) ; ) { LocalDate today = LocalDate.now ( ZoneId.of ( "America/Montreal" ) ); preparedStatement.setObject ( 1 , today.minusDays ( 1 ) ); // Yesterday. preparedStatement.executeUpdate ( ); preparedStatement.setObject ( 1, today ); // Today. preparedStatement.executeUpdate ( ); preparedStatement.setObject ( 1, today.plusDays ( 1 ) ); // Tomorrow. preparedStatement.executeUpdate ( ); } // Query all. sql = "SELECT * FROM test_"; try ( ResultSet rs = stmt.executeQuery ( sql ) ; ) { while ( rs.next ( ) ) { UUID id = rs.getObject ( "id_" , UUID.class ); // Pass the class to be type-safe. LocalDate localDate = rs.getObject ( "date_", LocalDate.class ); // Pass class for type-safety. System.out.println ( "id_: " + id + " | date_: " + localDate ); } } } catch ( SQLException e ) { e.printStackTrace ( ); } } }
Das obige ist der detaillierte Inhalt vonWie nutzt man java.time-Typen effektiv mit JDBC für Datenbankinteraktionen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

JavaremainsAgoodlanguageduetoitscontinuousevolutionandrobustEcosystem.1) LambdaexpressionenhanceCodereadabilityAnableFunctionalprogramm.

Javaisgratduetoitsplattformindependenz, robutepoopsupport, extensinstivibrary und Strongcommunity.1) PlattformindependenzenviajvMallowsCodetorunonvariousPlatforms.2) oopfeatures Likecapsulation, Erbe und PolymorphoseMendeularsCalablcode.3)

Die fünf Hauptmerkmale von Java sind Polymorphismus, Lambda -Ausdrücke, Streamsapi, Generika und Ausnahmebehandlung. 1. Polymorphismus ermöglicht es, Objekte verschiedener Klassen als Objekte gemeinsamer Basisklassen zu verwenden. 2. Lambda -Ausdrücke machen den Code prägnanter, insbesondere für die Handhabung von Sammlungen und Streams. 3.Streamsapi verarbeitet effizient große Datensätze und unterstützt deklarative Vorgänge. 4. Generika bieten Typensicherheit und Wiederverwendbarkeit, und während der Zusammenstellung werden Typfehler aufgenommen. 5. Ausnahmebehandlung hilft, fehlerfrei zu handhaben und zuverlässige Software zu schreiben.

Java'StopfeaturessinifificteNtationHancePSperformanceandScalability.1) Objektorientierte Principles LikepolymorphismenableFlexiBleandsCalableCode.2) garbagebackecollectionAutomatomatomatomatomatomatomatomatomatomatomatomatomatomatomatomatomatesMorymanagementbutcancauselatissues.3) Die

Zu den Kernkomponenten des JVM gehören Classloader, RunTimedataara und ExecleateEngine. 1) Classloader ist für das Laden, Verknüpfen und Initialisieren von Klassen und Schnittstellen verantwortlich. 2) Runtimedataara enthält Methoden-, Haufen-, Stapel-, PCregister- und Nativemethodstacks. 3) ExecXesionEngine besteht aus Dolmetscher, Jitcompiler und GarbagebyCollector, der für die Ausführung und Optimierung von Bytecode verantwortlich ist.

JvMenablesjavas "Writeonce, RunaNywhere" -BaskotbekenntnisCodeIntoplatform-INDEPENTEDBYTECODE

Die Auswirkungen der JVM -Version auf Java -Programme umfassen Kompatibilität, Leistungsoptimierung, Richtlinien für die Müllsammlung, Sicherheit und Sprachmerkmale. 1) Kompatibilität: Stellen Sie sicher, dass die Code- und Abhängigkeitsbibliotheken auf dem neuen JVM ausgeführt werden. 2) Leistung: Die neue JVM verbessert die Müllsammlung und die JIT -Kompilierungsleistung. 3) Sicherheit: Beheben Sie Sicherheitslücken und verbessern Sie die Gesamtsicherheit. 4) Neue Funktionen: Lambda -Ausdrücke von Java 8 und ZGC Müllsammler von Java 17, Vereinfachung des Code und Verbesserung der Effizienz.

JVM implementiert Javas "einmal schreiben, überall rennen", indem Java-Bytecode in maschinenspezifische Anweisungen umwandelt. 1. Der Klassenlader lädt die Klasse. 2. Speichern Sie Daten im Laufzeitbereich. 3. Führen Sie die Engine aus, um Bytecode umzuwandeln. 4.JNI ermöglicht die Interaktion mit anderen Sprachen. 5. Die lokale Methodbibliothek unterstützt JNI -Anrufe.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung
