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

JSF Java Discussion :

JSF Problème sur formulaire de recherche


Sujet :

JSF Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Octobre 2013
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2013
    Messages : 29
    Par défaut JSF Problème sur formulaire de recherche
    Bonjour,

    J'ai une table livre et je veux effectué la recherche par titre mais ça fonctionne pas.

    LivreBean.java
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    public Livre getLivreByTitle()
        {  
            return lDao.getByTitle(motCle);
        }
    public void SetLivreByTitle(String title)
        {
            this.motCle=title;
        }
    LivreDao.java
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    public Livre getByTitle(String titre)
        {
            Query query = em.createQuery("SELECT t FROM Livre t where t.titre= :title");
            query.setParameter("title","titre");
            Livre result = (Livre) query.getSingleResult();
            return result;
        }
    recherche.xhtml
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <h:panelGrid columns="3">
     
            <h:outputLabel value="Search: "/>
            <h:inputText id="keyword" value="#{livreBean.motCle}" required="true" label="Keyword" />
            <h:commandButton value="Ajouter"  action="Emprunt.xhtml"/>
        </h:panelGrid>
    affichage
    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
    <h:dataTable value="#{livreBean.livreByTitle}" var="l" border="2" rowClasses="row1,row2">
            <h:column>
                <f:facet name="header">
                    <h:outputText value="ID"/>
                </f:facet>
                <h:outputText value="#{l.idElement}"/>
     
            </h:column>
            <h:column>
                <f:facet name="header">
                    <h:outputText value="nom"/>
                </f:facet>
                <h:outputText value="#{l.isbn}"/>
            </h:column>
            <h:column>
                <f:facet name="header">
                    <h:outputText value="prenom"/>
                </f:facet>
                <h:outputText value="#{l.titre}"/>
            </h:column>
            <h:column>
                <f:facet name="header">
                    <h:outputText value="adresse"/>
                </f:facet>
                <h:outputText value="#{l.categorie}"/>
            </h:column>
            <h:column>
                <f:facet name="header">
                    <h:outputText value="telephone"/>
                </f:facet>
                <h:outputText value="#{l.etat}"/>
            </h:column>
     
    </h:dataTable>
    l'erreur:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Caused by: javax.persistence.NoResultException: getSingleResult() did not retrieve any entities.
    Mais je sais pas pourquoi le mot clé n'arrive pas à la requête. Merci de m'aider, je n'arrive pas à résoudre ça.

  2. #2
    Membre Expert Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Par défaut
    salut,
    comme il te dit, il n´a rien trouvé.
    soit tu fais un:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
       public Livre getByTitle(String titre)
      {
     List<Livre> livres = query.getResultList();
      Livre result = null;
      if(livres != null && livres.size() == 1)
         result = livres.get(0);
      return result;
     }
    ou tu geres cela autrement:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
     
      public Livre getByTitle(String titre)
      {
        try{
          Query query = em.createQuery("SELECT t FROM Livre t where t.titre= :title");
          query.setParameter("title","titre");
          Livre result = (Livre) query.getSingleResult();
          return result;
         } catch(NoResultException e) {
            return null;
        }
      }
    eric

  3. #3
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Octobre 2013
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2013
    Messages : 29
    Par défaut
    Merci pour ta reponse , j ai essayé les deux solutions mais il me dit toujours :dao.__EJB31_Generated__LivreDao__Intf____Bean__.getByTitle(Unknown Source) .
    alors le paramétre titre ne reçoit rien pour faire la sélection.
    des idées SVP??

  4. #4
    Membre Expert Avatar de jeffray03
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2008
    Messages
    1 501
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Allemagne

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juillet 2008
    Messages : 1 501
    Par défaut
    remplace donc par:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Query query = em.createQuery("SELECT t FROM Livre t where t.titre=  ?");
          query.setParameter(1,"titre");

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    146
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 146
    Par défaut
    Je ne sais pas si c'est une erreur de frappe mais la fonction setParameter prend en parametre un string (le nom du champ concerné) et un objet (la valeur).

    Donc pour moi au lieu d'écrire sa :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    query.setParameter("title","titre");
    il faudrait écrire sa :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    query.setParameter("titre",titre);
    J'ai mis "titre" comme j'ai vu que dans la commande sql le champ titre et non title était concerné...

  6. #6
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    Citation Envoyé par Lolosan Voir le message
    il faudrait écrire sa :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    query.setParameter("titre",titre);
    non ! le nom du paramètre est le nom indiqué dans la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Query query = em.createQuery("SELECT t FROM Livre t where t.titre= :title");
    Et dans le cas présent, c'est bien "title"
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  7. #7
    Modérateur
    Avatar de Alkhan
    Homme Profil pro
    ingénieur full stack
    Inscrit en
    Octobre 2006
    Messages
    1 232
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : ingénieur full stack

    Informations forums :
    Inscription : Octobre 2006
    Messages : 1 232
    Par défaut
    bonjour,

    le problème n'est pas la requête, mais le paramètre !
    Ta methode getByTitle prend en paramètre une chaine dans la variable titre, mais tu ne la set pas dans le query, car à la place tu lui donnes la chaîne "titre".
    Donc sauf si tu as un livre dont le titre est "titre", ta requête ne te ramènera jamais rien
    il faut que tu écrives :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    query.setParameter("title",titre);
    Il n'y a pas de problème, il n'y a que des solutions.
    Cependant, comme le disaient les shadoks, s'il n'y a pas de solution, c'est qu'il n'y a pas de problème.
    Si toutefois le problème persiste, la seule solution restante est de changer le périphérique qui se trouve entre la chaise et l'écran

    Mes Articles : Mon premier article est sur le language D
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  8. #8
    Membre averti
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Octobre 2013
    Messages
    29
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Maroc

    Informations professionnelles :
    Activité : Chargé d'affaire
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2013
    Messages : 29
    Par défaut
    j ai essayé tous ce que vous m'avet dit ,mais toujours il me dit : dao.__EJB31_Generated__LivreDao__Intf____Bean__.getByTitle(Unknown Source)

    caused by : An exception occurred while creating a query in EntityManager:
    Exception Description: Syntax error parsing [SELECT t FROM Livre t where t.titre = ?].
    [38, 39] The parameter value is missing from the input parameter.

Discussions similaires

  1. problème de formulaire de recherche
    Par mmanta1 dans le forum IHM
    Réponses: 1
    Dernier message: 18/06/2007, 19h36
  2. Réponses: 7
    Dernier message: 11/01/2007, 20h49
  3. Problème sur moteur de recherche
    Par itachi64 dans le forum ASP
    Réponses: 9
    Dernier message: 24/03/2006, 14h41
  4. Problèmes sur formulaire
    Par Alexandre Sahli dans le forum Access
    Réponses: 1
    Dernier message: 11/03/2006, 23h00
  5. [débutant]petit problème sur formulaire avec onglets
    Par Christophe93250 dans le forum Access
    Réponses: 2
    Dernier message: 06/01/2006, 10h46

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