IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Hibernate Java Discussion :

Décallage d'un jour lors de l'insertion d'une date en base de données


Sujet :

Hibernate Java

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Juillet 2013
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juillet 2013
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Décallage d'un jour lors de l'insertion d'une date en base de données
    Bonjour,

    J'utilise JAVA SPRING BOOT / Hibernate JPA pour gérer la partie application. La partie Front est en Angular 7.
    Lorsque je manipule des champs de type Timestamp en lecture, tout se passe très bien, mon formulaire affiche bien la donnée présente en base de données.
    En local sur le poste de développement, lorsque je modifie la valeur du formulaire, j'ai la bonne valeur dans ma base de données (également locale). Par contre, si j'utilise le serveur Linux (AWS - EC2, Linux AMI) et la base de données Postgres (AWE-RDS), j'ai un décalage lors de l'enregistrement en base de données de 1 jour. Par exemple, je renseigne le 01/01/2019, en base de données, je vais avoir 31/12/2018.

    Coté code, j'utilise le code suivant :
    @Temporal(TemporalType.DATE)
    @JsonFormat(pattern="dd/MM/yyyy")
    @Column(name="start_date")
    private Date startDate;

    1 jour ne me semble pas compatible avec la gestion de fuseaux horaires.

    Si vous avez des idées, merci d'avance pur vos retours

  2. #2
    Membre confirmé Avatar de Kazh Du
    Homme Profil pro
    Développeur Java
    Inscrit en
    Novembre 2011
    Messages
    152
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2011
    Messages : 152
    Points : 561
    Points
    561
    Par défaut
    Citation Envoyé par stephidric Voir le message
    1 jour ne me semble pas compatible avec la gestion de fuseaux horaires.
    Heu... bin si...
    Si tu utilise une date localisée (GMT+2 heure d'été en France métropolitaine) sur une date pure (sans heure/minute/seconde) pour 01/01/2019 (soit 01/01/2019 - 00:00:00 GMT+2) tu te retrouves avec une date du type "31/12/2018 22:00:00".
    Les heures ne sont pas sauvegardées et hop, décalage d'un jour entier.

    Je ne te garantis pas que c'est la cause, mais tu peux creuser de ce côté.
    Merci d'ajouter un sur les tags qui vous ont aidé

  3. #3
    Membre éprouvé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2012
    Messages
    631
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2012
    Messages : 631
    Points : 1 220
    Points
    1 220
    Par défaut
    évidement java.util.Date dépend de la locale du système hébergeant la machine virtuelle.
    Il faut tout de même vérifier que EC2 a la bonne timezone.Depuis une console linux:
    cette commande affiche outre la date locale mais aussi la time zone. à toi de modifier la timezone de ton instance.

    jackson se base également sur la timezone du système pour sérializer le document JSON en objet Date.Sûrement que c'est à ce niveau que ça foire. Mais tu peux indiquer à jackson la timezone à utiliser:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    @Temporal(TemporalType.DATE)
    @JsonFormat(pattern="dd/MM/yyyy", timezone="Europe/Paris")
    @Column(name="start_date")
    private Date startDate;
    ou dans le fichier application.properties
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    spring.jackson.time-zone=Europe/Paris
    dans tous les cas sans la bonne timezone tu risques d'obtenir à l'affichage des dates inexactes suite à une requête jpl( ou native query) faisant intervenir un calcul sur les dates.

Discussions similaires

  1. Réponses: 0
    Dernier message: 16/04/2017, 22h27
  2. [2.x] insertion d une date en base
    Par DidG_like dans le forum Symfony
    Réponses: 6
    Dernier message: 02/05/2012, 16h27
  3. Erreur SQL lors de l'insertion d'une date
    Par jdvacheron dans le forum Langage SQL
    Réponses: 2
    Dernier message: 23/07/2007, 16h31
  4. [MySQL] insertion d'une image en base de données
    Par SENCABOY dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 16/02/2006, 11h07
  5. maj d'1 colonne avec la date du jour lors de l'INSERT
    Par Celina dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 18/12/2003, 15h03

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo