Maison Java javaDidacticiel Comment gérer les objets java.time avec JDBC dans la base de données H2 ?

Comment gérer les objets java.time avec JDBC dans la base de données H2 ?

Dec 31, 2024 pm 07:02 PM

How to Handle java.time Objects with JDBC in H2 Database?

Échange de données JDBC avec des objets java.time

Question : Comment puis-je inclure les types java.time dans mon Base de données SQL utilisant JDBC, en particulier le moteur de base de données H2 ?

Réponse : Il existe deux méthodes pour orchestrer l'échange de données avec des objets java.time via JDBC :

Pilotes compatibles JDBC 4.2

  • Avec des pilotes JDBC compatibles avec JDBC 4.2 ou supérieur , vous pouvez manipuler directement les objets java.time.
  • Le comité JDBC a incorporé les méthodes setObject/getObject pour gérer ceci, éliminant le besoin de méthodes de type setLocalDate/getLocalDate.
  • Pour insérer des données, utilisez la méthode setObject avec votre objet java.time comme argument.
  • Pour la récupération de données, utilisez getObject méthode avec le type de données attendu comme argument supplémentaire, garantissant la sécurité du type.

Non-JDBC 4.2 Pilotes compatibles

  • Pour les pilotes JDBC qui ne sont pas encore compatibles avec JDBC 4.2, convertissez temporairement entre les types java.time et java.sql.
  • Utilisez java.sql.Date. valueOf pour convertir LocalDate en java.sql.Date pour l'insertion.
  • Pour la récupération, convertissez le récupéré java.sql.Date dans LocalDate à l'aide de sa méthode toLocalDate.

Exemple de code utilisant la base de données H2

Conforme à JDBC 4.2

LocalDate today = LocalDate.now(ZoneId.of("America/Montreal"));

// Insert row
preparedStatement.setObject(1, today.minusDays(1));
preparedStatement.executeUpdate();
preparedStatement.setObject(1, today);
preparedStatement.executeUpdate();
preparedStatement.setObject(1, today.plusDays(1));
preparedStatement.executeUpdate();

// Retrieve data
LocalDate localDate = myResultSet.getObject("date_", LocalDate.class);
Copier après la connexion

Non-JDBC 4.2 Conforme

// Insert row
preparedStatement.setDate(1, java.sql.Date.valueOf(today));
preparedStatement.executeUpdate();

// Retrieve data
java.sql.Date sqlDate = myResultSet.getDate("date_");
LocalDate localDate = sqlDate.toLocalDate();
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Vous avez un jeu croisé?
1 Il y a quelques mois By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)