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

Servlets/JSP Java Discussion :

Erreur sur une boucle while


Sujet :

Servlets/JSP Java

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Août 2012
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2012
    Messages : 3
    Points : 1
    Points
    1
    Par défaut Erreur sur une boucle while
    Bonjour

    Je me sert souvent de ce forum pour trouver des solution à mes problème.
    Mais jusqu’à aujourd'hui j'étais toujours arrivé à trouvé la solution sans problème.
    Mais là j'avoue que je sèche.

    Je suis en train de travailler sur une boucle while qui a décidée de ne pas fonctionner... j'ai cherché dans tous les coin impossible de trouver.

    Le but étant de créer un tableau à longueur variable

    Voila le code concerné
    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
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
     
       <div id="onglet-3">
          <table>
    			<tr>
    				<td class="attributeName">
    					Type de reseau
    				</td>
    				<td class="attributeName">
    					Gestionaire
    				</td>
    			</tr>
    <%
       //F. Construction de la requête SQL concernant les Réseaux_Voirie
                    StringBuffer sqlReseauVoirie = new StringBuffer();
                    sqlReseauVoirie.append ("SELECT * FROM troncon_reseaux WHERE troncon_id = " + strIdVoirie);
       
            ResultSet pResultSetReseauVoirie = pStatement.executeQuery (sqlReseauVoirie.toString());
            
      //G. Recherche de l ID réseaux
               String strId_Reseau = null;
            
            While (pResultSetReseauVoirie.next()){
            
                      strId_Reseau = pResultSetReseauVoirie.getString ("reseau_id");   
     
                      if (strId_Reseau != null)
                             strId_Reseau = strId_Reseau.trim();
     
               //H. Construction de la requête SQL concernant les Réseaux
                            StringBuffer sqlReseau = new StringBuffer();
                            sqlReseau.append ("SELECT * FROM Reseaux WHERE objectid = " + strId_Reseau);
     
                    ResultSet pResultSetReseau = pStatement.executeQuery (sqlReseau.toString());
     
            //I. Recherche des infos réseaux
               String strPrestataire = null;
               String strTypeReseaux = null;
                    
            if (pResultSetReseau.next())
               {    
                      strPrestataire = pResultSetReseau.getString ("prestataire");   
                      strTypeReseaux = pResultSetReseau.getString ("type_reseaux");  
     
                      if (strPrestataire != null)
                             strPrestataire = strPrestataire.trim();
                      if (strTypeReseaux != null)
                             strTypeReseaux = strTypeReseaux.trim();
    %>			
    			<tr>
    				<td class="attributeValue">
    <%
                                       strPrestataire = StringHelper.replaceNull (strPrestataire, "-");
                                       strPrestataire = StringHelper.replaceSpecialChar (strPrestataire);
                                       out.println (strPrestataire);
    %>
    				</td>
    				<td class="attributeValue">
    <%
                                       strTypeReseaux = StringHelper.replaceNull (strTypeReseaux, "-");
                                       strTypeReseaux = StringHelper.replaceSpecialChar (strTypeReseaux);
                                       out.println (strTypeReseaux);
    %>
    				</td>
    			</tr>
    <%
                    }
       pResultSetReseau.close();
            }
    //      
       pResultSetReseauVoirie.close();      
    %>
    	  </table>
       </div>
    Pour expliquer mon code.
    Je cherche dans un 1er temps les enregistrement dans ma table de jointure qui correspondent à mon tronçon (ID que j'ai récupéré précédement).
    Ensuite je veux faire un boucle qui va aller chercher dans ma table de jointure l'identifiant d'un réseau.
    Ce qui va me permettre d'aller faire une 2ème requête sur la table des réseaux grâce a lID que je viens de récupéré.
    Enfin je vais remplir le reste de mon tableau avec les infos trouvées.

    Sauf que je me tape une erreur du style
    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
     
    Une erreur s'est produite à la ligne: 297 dans le fichier jsp: /jsp/consultations/jsp/consultationVoirie.jsp
    The method While(boolean) is undefined for the type consultationVoirie_jsp
    294:   //G. Recherche de l ID réseaux
    295: 	   String strId_Reseau = null;
    296: 	
    297: 	While (pResultSetReseauVoirie.next()){
    298: 	
    299: 		  strId_Reseau = pResultSetReseauVoirie.getString ("reseau_id");   
    300: 
     
     
    Une erreur s'est produite à la ligne: 297 dans le fichier jsp: /jsp/consultations/jsp/consultationVoirie.jsp
    Syntax error, insert ";" to complete Statement
    294:   //G. Recherche de l ID réseaux
    295: 	   String strId_Reseau = null;
    296: 	
    297: 	While (pResultSetReseauVoirie.next()){
    298: 	
    299: 		  strId_Reseau = pResultSetReseauVoirie.getString ("reseau_id");   
    300:
    En essayant de modifier mon code je suis aussi tombé sur des erreur du genre " le resultset pResultSetReseauVoirie est fermé"

    Alors que si je remplace le "While" par un"IF", là pas de soucis sauf que j'ai qu'une seul ligne dans mon tableau.

    Si vous avez une idée... (je sens bien que ça va être une erreur stupide)
    Merci d'avance

  2. #2
    Modérateur

    Avatar de Robin56
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juin 2009
    Messages
    5 297
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juin 2009
    Messages : 5 297
    Points : 13 670
    Points
    13 670
    Par défaut
    C'est normal le While avec une majuscule au W ?
    Responsable Java de Developpez.com (Twitter et Facebook)
    Besoin d'un article/tutoriel/cours sur Java, consulter la page cours
    N'hésitez pas à consulter la FAQ Java et à poser vos questions sur les forums d'entraide Java
    --------
    Architecte Solution
    LinkedIn : https://www.linkedin.com/in/nicolascaudard/

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Août 2012
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2012
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Rohh le boulet que je suis...

    Merci ça m'a supprimé une erreur bête mais elle a évolué pour m'en donner une autre.

    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
    48
    49
     
    org.apache.jasper.JasperException: An exception occurred processing JSP page /jsp/consultations/jsp/consultationVoirie.jsp at line 297
     
    294:   //G. Recherche de l ID réseaux
    295: 	   String strId_Reseau = null;
    296: 	
    297: 	while (pResultSetReseauVoirie.next()){
    298: 	
    299: 		  strId_Reseau = pResultSetReseauVoirie.getString ("reseau_id");   
    300: 
     
     
    Stacktrace:
    	org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:510)
    	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:401)
    	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    	com.imagis.geowt.core.server.filter.GeoWTServiceResponseHeaderFilter.doFilter(GeoWTServiceResponseHeaderFilter.java:30)
     
    cause mère
     
    javax.servlet.ServletException: org.postgresql.util.PSQLException: Ce ResultSet est fermé.
    	org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:862)
    	org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:791)
    	org.apache.jsp.jsp.consultations.jsp.consultationVoirie_jsp._jspService(consultationVoirie_jsp.java:430)
    	org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
    	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    	com.imagis.geowt.core.server.filter.GeoWTServiceResponseHeaderFilter.doFilter(GeoWTServiceResponseHeaderFilter.java:30)
     
    cause mère
     
    org.postgresql.util.PSQLException: Ce ResultSet est fermé.
    	org.postgresql.jdbc2.AbstractJdbc2ResultSet.checkClosed(AbstractJdbc2ResultSet.java:2674)
    	org.postgresql.jdbc2.AbstractJdbc2ResultSet.next(AbstractJdbc2ResultSet.java:1806)
    	org.apache.tomcat.dbcp.dbcp.DelegatingResultSet.next(DelegatingResultSet.java:207)
    	org.apache.tomcat.dbcp.dbcp.DelegatingResultSet.next(DelegatingResultSet.java:207)
    	org.apache.jsp.jsp.consultations.jsp.consultationVoirie_jsp._jspService(consultationVoirie_jsp.java:360)
    	org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
    	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    	org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:377)
    	org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:313)
    	org.apache.jasper.servlet.JspServlet.service(JspServlet.java:260)
    	javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
    	com.imagis.geowt.core.server.filter.GeoWTServiceResponseHeaderFilter.doFilter(GeoWTServiceResponseHeaderFilter.java:30)
    Il me dit que mon resultset est fermé alors que je le ferme après la boucle while

    Une autre idée ?
    Merci d'avance

  4. #4
    Nouveau Candidat au Club
    Homme Profil pro
    Inscrit en
    Août 2012
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2012
    Messages : 3
    Points : 1
    Points
    1
    Par défaut
    Pour infos l'erreur venait du fait que je n'utilisais qu'un seul Statement pour mes 2 requêtes
    Or la doc dit bien qu'en cas de requete imbriqué il ne faut pas utiliser les mêmes.

    By default, only one ResultSet object per Statement object can be open at the same time. Therefore, if the reading of one ResultSet object is interleaved with the reading of another, each must have been generated by different Statement objects. All execution methods in the Statement interface implicitly close a statment's current ResultSet object if an open one exists.
    Voila merci pour le coup de main

Discussions similaires

  1. [MySQL] Erreur sur une boucle While
    Par PrinceMaster77 dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 01/12/2009, 11h42
  2. [E07] erreur sur une boucle avec condition
    Par rvtoulon dans le forum Macros et VBA Excel
    Réponses: 15
    Dernier message: 18/03/2009, 14h59
  3. erreur sur une boucle ?
    Par artotal dans le forum Langage
    Réponses: 1
    Dernier message: 06/09/2008, 17h52
  4. Gestion des erreurs dans une boucle While
    Par Gregory.M dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 12/08/2008, 20h57
  5. erreur sur une boucle
    Par guismoman33 dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 30/05/2007, 13h38

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