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 :

problème de typage


Sujet :

Servlets/JSP Java

  1. #1
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut problème de typage
    Bonsoir,

    j'ai une page web dans laquelle j'ai ce petit morceau de code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     <%java.util.List data=list.getDataNum(secu);
               for(int i=0; i<data.size();i++){
               java.util.List line = (java.util.List)data.get(i);
               String numero=(String)line.get(0);
               String maladie=(String)line.get(1);%>
    J'ai une page java ListNbr dans laquelle j'ai la méthode getDataNum :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
      public List <List <String>> getDataNum(long num) throws ListCamedelException{
            try{
            data=f.requete("SELECT * FROM Nombre WHERE Nombre.numero='"+num+"';");
            return data; ...
    Je n'arrive pas à passer le num en paramètre.
    Ca me met l'erreur :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    getDataNum(java.lang.long) in listes.ListNbr cannot be applied to (java.lang.Object)
    Si j'utilise getDataNum sans le where donc sans paramètre, tout fonctionne.
    Pourriez vous me dire où est l'erreur ?

    Merci

  2. #2
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    quelqu'un a une idée ?
    MERCI

  3. #3
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    Dans ta jsp, secu est de quel type??

    Quand tu dis que ca marche sans le where, tu enleves les arguments à ta methode getDataNum()?
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  4. #4
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    Pour être très rapide, je pense que si tu mets :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    public List <List <String>> getDataNum(String num) throws ListCamedelException{
            try{
            data=f.requete("SELECT * FROM Nombre WHERE Nombre.numero='"+num+"';");
            return data; ...
    Ca marchera!! Si je me trompe alors répond au question d'avant, lol!
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  5. #5
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    je n'ai pas déclaré secu dans ma jsp,
    je le récupère grâce à un bean:define
    dans la base de donnée, c'est un entier long

    oui quand j'enlève le where et les arguments de la fonction cela fonctionne mais ce n'est pas ce que je voudrais

  6. #6
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    Ok, alors quand tu definis ton bean essaye ca mais ca m'étonnerait que ca marche :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <bean:define id="secu" name"............" type="long"/>

    Sinon si ca ne marche pas, fait ca quand tu le defini

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <bean:define id="secu" name"............" type="java.lang.String"/>
    Et fait aussi la modif que je t'ai dit de faire juste en dessous.
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  7. #7
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    merci ca marche en mettant type dans le bean:define

    j'ai encore une petite question, voici mon code :
    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
     
     
               <bean:define id="num"  name="nbr" property="num" type="java.lang.String"/>
               Bonjour <%= num %>
     
                              <%java.util.List data=listMaladie.getDataNum(num);
                                    for(int i=0; i<data.size();i++){
                                        java.util.List line = (java.util.List)data.get(i);
                                            String numero=(String)line.get(0);
                                            String maladie=(String)line.get(1);%>
                                            <tr>
                                            <td></td>
                                            <td></td>
                                              <td><strong><%=(String)maladie%></strong></td>
                                              <td></td>
                                              <td></td>
                                                           <% } %>
    Quand je met num prend bien la bonne valeur mais elle n'est pas dans la fonction getDataNum(num). Ca me met une erreur comme si elle était nulle

  8. #8
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    Oui la il m'en faut un peu plus.

    Donne moi l'erreur.
    Et met un breakpoint pour debugguer ou si tu n'arrives pas essaye de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    System.out.println("num");
    Au tout debut de ta methode getDataNum.
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  9. #9
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    Voici l'erreur

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    org.apache.jasper.JasperException: pb C:/temp/bdd.mdb :[Microsoft][Pilote ODBC Microsoft Access] Trop peu de paramètres. 1 attendu.

  10. #10
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    La c'est clairement un probleme soit avec ta requete, soit avec tes resultats.

    Ecrit ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
     <%java.util.List data=list.getDataNum(secu);
               System.out.println("Secu :"+secu);
               for(int i=0; i<data.size();i++){
               java.util.List line = (java.util.List)data.get(i);
               String numero=(String)line.get(0);
               System.out.println("Numero :"+numero);
               String maladie=(String)line.get(1);
               System.out.println("Maladie :"+maladie);
               %>
    Et dit moi ce qui est écrit dans ta console.
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  11. #11
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    toujours le même problème :
    trop peu de paramètre. 1 attendu

  12. #12
    Membre expérimenté Avatar de maxf1
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France, Moselle (Lorraine)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 229
    Points : 1 371
    Points
    1 371
    Par défaut
    Je sais. As tu lu mon post?

    Et dit moi ce qui est écrit dans ta console.
    Je te demandé le log de la console pour savoir ce qu'il y a d'affiché.
    Car je n'ai rien changé au code si ce n'est d'affiché du semblant de log.
    Une solution a été apporté pour résoudre votre problème alors vous aussi faites en profitez les autres grâce au tag qui se trouve tout en bas de la page....

    Merci de ne pas utiliser les messages privés pour un problème sauf si je vous l'ai explicitement demandé.

    -- Maxf1 --

  13. #13
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 310
    Points : 9 522
    Points
    9 522
    Billets dans le blog
    1
    Par défaut
    De quel type est numero dans ta base ?
    Parceque si c'est un numérique, il ne faut pas mettre entre ' la valeur, exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    // Si Nombre.numero représente une colonne numérique :
    SELECT * FROM Nombre WHERE Nombre.numero='10' // plantage, ça c'est pour une colonne VARCHAR
    SELECT * FROM Nombre WHERE Nombre.numero=10  // OK, tu trouves
    A+
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  14. #14
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    c'est un numérique

    je dois mettre ca alors ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    WHERE Numero.numero="+num+"

  15. #15
    Modérateur
    Avatar de OButterlin
    Homme Profil pro
    Inscrit en
    Novembre 2006
    Messages
    7 310
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 7 310
    Points : 9 522
    Points
    9 522
    Billets dans le blog
    1
    Par défaut
    Et oui, tout à fait

    A+
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  16. #16
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    301
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2006
    Messages : 301
    Points : 75
    Points
    75
    Par défaut
    merci c'était ca mon problème
    merci à tous

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 11/04/2007, 16h42
  2. Réponses: 6
    Dernier message: 25/02/2007, 17h56
  3. [Typage] Problème avec typage de variables
    Par elitemedia dans le forum Langage
    Réponses: 2
    Dernier message: 17/11/2006, 02h18
  4. [Tableaux] Problème de typage sur un float
    Par Lomu dans le forum Langage
    Réponses: 1
    Dernier message: 06/11/2006, 11h47
  5. [SQL2005] problèmes de typage de colonne en XML
    Par titouc330 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/10/2006, 12h52

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