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 :

Erreur quand la requete ne trouve pas le résultat


Sujet :

Persistance des données Java

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2008
    Messages
    21
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 21
    Points : 18
    Points
    18
    Par défaut Erreur quand la requete ne trouve pas le résultat
    Bonsoir,

    Voila j'utilie un formulaire en JSP qui appelle a travers plusieurs méthodes ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
         public Utilisateur getUtilisateurByLogin(String login, String mdp) {
            Query query = em.createQuery("SELECT utilisateur FROM Utilisateur AS utilisateur WHERE utilisateur.login = :login AND utilisateur.password = :mdp");
            query.setParameter("login", login);
            query.setParameter("mdp",mdp);
            return (Utilisateur) query.getSingleResult();
     
        }
    Donc mon probleme est que quand il ne trouve pas le bon login et mdp tapez par l'user il me met cette erreur :

    javax.servlet.ServletException: #{UtilisateurPoster.authentificationUser}: javax.ejb.EJBException: nested exception is: java.rmi.ServerException: RemoteException occurred in server thread; nested exception is:
    java.rmi.RemoteException: null; nested exception is:
    javax.ejb.TransactionRolledbackLocalException: Exception thrown from bean; nested exception is: javax.persistence.NoResultException: getSingleResult() did not retrieve any entities.
    root cause


    la methode appeller une fois le formulaire remplit est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
            public String authentificationUser(){
     
        System.out.println(">>>>>>>>>>>>>>>>" + getUtilisateur().getLogin());
     
        utilisateur =  utilisateurService.getUtilisateurByLogin(getUtilisateur().getLogin(), getUtilisateur().getPassword());
     
        if(utilisateur != null){
     
            return "indexAdmin";  
          }else{
     
         return "index";
         }
    Merci d'avance

  2. #2
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 274
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 274
    Points : 4 141
    Points
    4 141
    Par défaut
    C'est un peu normal, puisque dans la doc, on voit que la méthode lance une exception s'il n'y a pas de résultat lors de la requête.

    http://www.hibernate.org/hib_docs/ej...SingleResult()

    Si tu ne veux pas d'exception, utilise la méthode getResultList() et récupère le premier élément s'il existe.

Discussions similaires

  1. Réponses: 0
    Dernier message: 29/08/2011, 14h44
  2. [CS5] erreur et je ne la trouve pas
    Par bellegueule dans le forum ActionScript 3
    Réponses: 3
    Dernier message: 03/01/2011, 17h35
  3. Réponses: 2
    Dernier message: 15/09/2008, 14h57
  4. Requete ne renvoyant pas le résultat souhaité
    Par tranzebou dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 06/08/2008, 16h15
  5. Ma requete a une erreur est je na la trouve pas
    Par Jamal_71 dans le forum MS SQL Server
    Réponses: 3
    Dernier message: 09/02/2006, 09h11

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