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

JDBC Java Discussion :

enregistrement date mais perte des hhmmss


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 69
    Points : 64
    Points
    64
    Par défaut enregistrement date mais perte des hhmmss
    Bonjour....

    Je viens chercher un peu d'aide car je ne trouve pas de solutions à mon probléme...

    j'ai une date au format dd/MM/yyyy HH:mm:ss

    mais quand je l'enregistre dans la base les HH:mm:ss se retrouve initialisé à zero....

    un peu de code pour vous aider à trouver mon erreur...


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
     
     
    Date d = collab.getDateEntree();
            System.out.println("datejava=" + d);
     
            Timestamp time = new Timestamp(d.getTime());
           collab.setDateEntree(time);
           System.out.println("madate enregistre est:" + time);
     
     
    String mareqajout = "INSERT INTO [Collaborateurs] " +
                    "([Nom]" +
                    ",[Prenom]" +
                    ",[DateEntree]" 
                    ")" +
                    "     VALUES" +
                    "           (?,?,?)";
    try {
                PreparedStatement prepa = conn.prepareStatement(mareqajout );
                prepa.setObject(1, collab.getNom());
                prepa.setObject(2, collab.getPrenom());
                prepa.setObject(3, collab.getDateEntree());
                rs = prepa.executeUpdate();
                System.out.println("madate= "+collab.getDateEntree());
     
            } catch (SQLException ex) {
                Logger.getLogger(Collaborateur.class.getName()).log(Level.SEVERE, null, ex);
            }

    Y a peut-etre du code en plus (du à des essais de ma part )

    les "system out" donnent:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     
    datejava=Thu Apr 02 17:20:42 CEST 2009
    madate enregistre est:2009-04-02 17:20:42.406
    madate= 2009-04-02 17:20:42.406
    resultat ajout=1

    mais dans ma base j'ai 2009-04-02 00:00:00.000 d'enregistré...
    j'ai essayé avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     prepa.setDate(3, new java.sql.Date(collab.getDateEntree().getTime()));
    mais ça change rien,.
    Mon champ est de type DateTime dans ma base sous SQLserver.

    J'avoue que les millisecondes, je peux m'en paser, mais ce champ date me sert à faire des tris et j'ai besoin des HH:mm:ss.

    Merci de m'orienter vers des solutions possibles...

  2. #2
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Que te retournes la méthode getDateEntree() exactement ?
    Cela devrait être un objet Timestamp...

    a++

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 69
    Points : 64
    Points
    64
    Par défaut
    Merci de me épondre si vite.

    mon objet collab :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
     
      public Collaborateur(int IdCollab, String nom, String Prenom, Date DateEntree){
    this.IdCollab = IdCollab;
            this.nom = nom;
            this.Prenom = Prenom;
            this.DateEntree = DateEntree;}
    avec les getter/setter

    mon instance de collab:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
    Date d = new Date();
        private int IdCollab = 0;
        private String nom = null;
        private String Prenom = "";
     
     Collaborateur collab = new Collaborateur(IdCollab, nom, Prenom, DateEntree);
    ...
     
     collab.setNom(jTNom.getText());
     collab.setPrenom(jTPrenom.getText());
     collab.setDateEntree(d);
    ma variable d ne bouge pas (date du jour)
    et j'envoie collab en parametre dans ma methode d'insertion.

    En bref getDateEntree() c'est Date d = new Date();

    Je teste avec TimeStamp....
    Merci

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Décembre 2007
    Messages
    69
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 69
    Points : 64
    Points
    64
    Par défaut
    Un grand merci...

    Ca marche avec Timestamp dans le constructeur.....

    Je pensais qu'il fallait avoir un java.util.date à cette endroit




    ++

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [AC-2003] Enregistrer Date et Heure des donnés d'une table vers une autre
    Par piwa6291 dans le forum Access
    Réponses: 8
    Dernier message: 20/03/2015, 14h41
  2. [AC-2003] Ajouter toutes dans ZL mais avec des dates
    Par electrosat03 dans le forum IHM
    Réponses: 1
    Dernier message: 31/03/2010, 22h08
  3. Réponses: 0
    Dernier message: 21/08/2009, 14h40
  4. Réponses: 4
    Dernier message: 10/11/2008, 17h17
  5. Date de création des enregistrements
    Par Ender dans le forum Access
    Réponses: 6
    Dernier message: 19/08/2006, 22h10

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