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

Collection et Stream Java Discussion :

fonction qui renvoie un tableau


Sujet :

Collection et Stream Java

  1. #1
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut fonction qui renvoie un tableau
    Bonjour,

    je dois faire une fonction qui doit retourner une liste des personnes sous forme de tableau. Voici sa signature:

    public Personne[] List()

    le problème est que je ne sais pas par où commencer.
    Des conseils?

    Merci

  2. #2
    Membre Expert Avatar de guigui5931
    Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2006
    Messages
    1 667
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 667
    Par défaut
    Je vais regarder dans ma boule de cristal....
    Il faut que tu précise ce que tu veux ... déja d'ou vienne tes personnes, comment les récupère tu ....

  3. #3
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    Précisons donc.
    Les personnes viennent d'une base de données, et je les récupère via JDBC.
    J'ai fait des méthodes pour insérer, updater et supprimer, et j'ai fait des test avec une classe Main très simple.
    Je regarde dans les bouquins, il faut que je commence par créer un tableau (je suppose) rempli de String(?); faut-il faire quelque chose qui va parcourir la base de données? sous quelle forme?

  4. #4
    Membre Expert Avatar de guigui5931
    Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2006
    Messages
    1 667
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 667
    Par défaut
    Il faut que tu execute ta requete, que tu récupère un ResultSet et que tu le parcours pour remplir ton tableau.

  5. #5
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    quel est le meilleur moyen pour parcourir un tableau?
    d'ailleurs, je dois déclarer un tableau multidimensionnel? Je dois récupérer nom, prénom, age, primary key (dans ma base test)

  6. #6
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 52
    Par défaut
    Ta méthode peut ressemblé a ça:
    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
     
    import java.util.ArrayList;
     
    public Class NomDeTaClasse extends NomDeLaClasseDeConnexionBDD
    {
    private ArrayList tonTableau;
     
     
    public ArrayList List()
    {
       methodeConnexion();
     
       methodeLecture(taRequete);
    tonTableau = new ArrayList();
       While(resultat.next())      // resultat est de type ResultSet, contient le resultat de ta requete
     
        {
              for(int i=1;i<=nombreDeColonne;i++)
              tonTableau.add(resultat.getString(i));
        } 
     
       return tonTableau;
    }
    }
    puis tu lis ton tableau par un sau de nombreDeColonne

  7. #7
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    Citation Envoyé par foubou Voir le message
    puis tu lis ton tableau par un sau de nombreDeColonne
    un sau?

  8. #8
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 52
    Par défaut
    Citation Envoyé par bandit_debutant Voir le message
    un sau?
    Un saut... dsl il manque le t, bref... a l'affichage, ton code doit ressembler a ça:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    int i = 0;
    while(i<tonTableau.size())
    {
    System.out.println("nom : "+tonTableau.get(i));
    System.out.println("prenom : "+tonTableau.get(i+1));
    System.out.println("age : "+tonTableau.get(i+2));
    System.out.println("key : "+tonTableau.get(i+3));
    i = i+4;
    }
    Le saut est égal a 4 dans ce cas.
    l'ordre d'affichage dépend de l'ordre de tes colonnes dans la table.

  9. #9
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    J'ai vu dans la FAQ à propos de resultSet, que le parcours se fait par rapport aux lignes avec la méthode next()
    Faut-il raisonner en termes de colonnes ou de lignes?

  10. #10
    Membre Expert Avatar de guigui5931
    Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2006
    Messages
    1 667
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 667
    Par défaut
    Les 2 mon capitaine. Tu parcours tes lignes, puis pour chaque ligne tu peux accéder à une colonne par son nom, son index ou parcourir toutes les colonnes comme foubou te l'a montré.

  11. #11
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    Citation Envoyé par guigui5931 Voir le message
    Les 2 mon capitaine. Tu parcours tes lignes, puis pour chaque ligne tu peux accéder à une colonne par son nom, son index ou parcourir toutes les colonnes comme foubou te l'a montré.
    OK. Mettons que je veuille parcourir mes lignes, et ej fais le code suivant
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    public Personne[] List() throws Exception
        {
           PreparedStatement tab = getPreparedStatement("SELECT * FROM TblPersonnes");
           ResultSet resultat = tab.executeQuery();
           Personne [] Liste = new Personne[40];
           while (resultat.next()){
               for (int i=1;i<=Liste.length;i++)
                   Liste.add(resultat.getString(i));
           }
           tab.getConnection().close();
           return Liste;
    }
    il ne veut pas de la ligne "Liste.add(resultat.getString(i));" à cause de add
    Comment ajouter donc la ligne au tableau?

  12. #12
    Membre Expert Avatar de guigui5931
    Profil pro
    Chef de projet NTIC
    Inscrit en
    Avril 2006
    Messages
    1 667
    Détails du profil
    Informations personnelles :
    Âge : 38
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 667
    Par défaut
    Je pense qu'il faut que tu t'intéresse à base du langage notamment à la manipulation de tableau.

  13. #13
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    Citation Envoyé par guigui5931 Voir le message
    Je pense qu'il faut que tu t'intéresse à base du langage notamment à la manipulation de tableau.
    message reçu

  14. #14
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 52
    Par défaut
    nombreDeColonnes c le nombre de colonnes dans ta table TblPersonnes, si ta table contient que key, nom, prenom et age, alors tu affecte la valeur 4 a nombreDeColonnes:

    remplace ça:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for (int i=1;i<=Liste.length;i++)
    par:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    int nombreDeColonnes = 4;
    for (int i=1;i<=nombreDeColonnes;i++)

  15. #15
    Membre confirmé Avatar de bandit_debutant
    Profil pro
    Inscrit en
    Juin 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juin 2006
    Messages : 133
    Par défaut
    Merci foubou

  16. #16
    Membre confirmé
    Inscrit en
    Mars 2007
    Messages
    52
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 52
    Par défaut
    Citation Envoyé par bandit_debutant Voir le message
    Merci foubou
    De rien

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

Discussions similaires

  1. fonction qui renvoie un tableau
    Par deubelte dans le forum C++
    Réponses: 24
    Dernier message: 26/05/2007, 01h51
  2. fonction qui renvoie un tableau
    Par GLSpirit dans le forum C++
    Réponses: 9
    Dernier message: 12/05/2007, 14h05
  3. fonction qui renvoie un tableau
    Par toto2022 dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 22/01/2007, 16h11
  4. Comment faire une fonction qui renvoi un tableau.
    Par poly128 dans le forum Delphi
    Réponses: 2
    Dernier message: 01/06/2006, 01h04
  5. Fonction qui renvoie un tableau?
    Par elm dans le forum C
    Réponses: 23
    Dernier message: 21/12/2005, 12h44

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