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

Persistance des données Java Discussion :

Seconde requête => erreur


Sujet :

Persistance des données Java

  1. #1
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut Seconde requête => erreur
    Bonjour.
    J'utilise SEAM (en débutant donc galère !) mais il semble que mon problème ne soit pas spécifique à SEAM.

    Dans le code ci-dessous, je commence par chercher un étudiant puis je lui génère un mot de passe et la seconde requête est censée enregistrer ce mot de passe dans la BDD. La table th_etudiant_etu hérite de la table th_candidat_cnd qui hérite de la table th_utilisateur_uti qui hérite de la table te_personne_prs.

    identification.java :
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
        public boolean identifier() 
        {
            try
            {
                log.info("identification.identifier() "
                        + "Tentative d'identification avec les paramètres suivants : "
                        + "#{identification.nom}, #{identification.prenom}, #{identification.dateNaissance}");
     
                // Recherche de l'étudiant
                Query query = entityManager.createQuery(
                        "from ThEtudiantEtu e " +
                        "where e.prsNom = :nom " +
                            "and e.prsPrenom = :prenom " +
                            "and e.etuDateNaissance = :dateNaissance ");
                query.setParameter("nom", this.getNom());
                query.setParameter("prenom", this.getPrenom());
                query.setParameter("dateNaissance", this.getDateNaissance());
     
                ThEtudiantEtu etudiant = (ThEtudiantEtu) query.getSingleResult();
     
                // Génération de son mot de passe
                this.setMotPasse(etudiant.generatePassword(this.getPrenom(), this.getNom()));
     
                log.info("identification.identifier() : affectation du mot de passe #{identification.motPasse}");
     
                Query q2 = entityManager.createQuery(
                        "UPDATE ThUtilisateurUti uti " +
                        "SET uti.utiMotPasse = :motPasse " +
                        "WHERE uti.utiLogin = :login ");
                q2.setParameter("motPasse", this.getMotPasse());
                q2.setParameter("login",etudiant.getUtiLogin());
                q2.executeUpdate();
     
                //identity.addRole(etudiant.getTeTypeUtilisateurTu().getTuLibelle());
                credentials.setUsername(etudiant.getUtiLogin());
                //credentials.setPassword(etudiant.getUtiMotPasse());
                //identity.login();
     
                //facesMessages.add("Votre identifiant de connexion est #{etudiant.getUtiLogin()}");
                //facesMessages.add("Votre mot de passe est #{etudiant.getUtiMotPasse()}");
     
                setAdmis(true);
     
                setPageSuivante("/login.xhtml");
                //setPageSuivante("/accueilEtudiant.xhtml");
                return true;
            }
    Et j'obtiens cette erreur, qui intervient au moment de la seconde requête :
    11:01:34,259 INFO [Identification] identification.identifier() : affectation du mot de passe T191110T
    org.hibernate.validator.InvalidStateException: validation failed for: org.domain.stamas.entity.ThEtudiantEtu
    at org.hibernate.validator.event.ValidateEventListener.validate(ValidateEventListener.java:148)
    ...
    Si je commente la requête q2 et son exécution, je n'ai plus l'erreur et ma redirection se passe bien.

    Quelqu'un peut me dire ce qui ne va pas ?
    Est-ce le fait que la seconde requête n'est pas faite sur la même table que la première ?

  2. #2
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 801
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 801
    Points : 34 063
    Points
    34 063
    Billets dans le blog
    14
    Par défaut
    Je relance cette discussion parce que même avec deux SELECT dans la même fonction Java, ça ne fonctionne pas !

    Je ne trouve nulle part d'exemple sur la manière de lancer plusieurs requêtes (au moins 2 donc ! ) à la suite comme on pourrait sans problème le faire en PHP :
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    $q1 = "SELECT des_colonnes
    FROM la_table
    WHERE une_condition";
    $reponse1 = mysql_query($q);
     
    // traitement sur $reponse
     
    $q2 = "SELECT autres_colonnes
    FROM autre_table
    WHERE autre_condition_basée_sur_traitement_$reponse";
    $reponse2 = mysql_query($q2);

    Impossible à faire en Java un truc aussi simple ?

Discussions similaires

  1. [SQL] Requête SQL erreur de syntaxe
    Par helopme_69 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 05/01/2008, 21h51
  2. Requête delete: Erreur ORA-00933
    Par loukili81 dans le forum Oracle
    Réponses: 13
    Dernier message: 09/08/2007, 19h04
  3. Problème de requête SQL - Erreur 3122
    Par Kornikopic dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 19/06/2007, 10h57
  4. division par 0 dans une requête donne #Erreur
    Par bugprog dans le forum Requêtes et SQL.
    Réponses: 5
    Dernier message: 29/05/2007, 09h57
  5. [Requête/SQL]Erreur Syntaxe Access
    Par LAETIAZ dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 23/04/2007, 12h29

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