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

Langage Java Discussion :

recuperation d'un type ResultSet par une autre classe


Sujet :

Langage Java

  1. #1
    Membre confirmé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Points : 575
    Points
    575
    Par défaut recuperation d'un type ResultSet par une autre classe
    bonjour
    j'ai une classe qui a des methodes dont une qui me permet de me connecter et d'effectuer une requete sql

    l'autre classe permet entre autre de recuperer les resultat de ma requete

    la classe de methode

    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
     
     
    public void Conec (String requet)
    	{
    		//Nom de mon pilote
    		String pilote = "com.mysql.jdbc.Driver";
     
    		try{
    			//Chargement de mon pilote
    			Class.forName(pilote);
    			//Connexion à ma base mysql avec mon login et mot de passe ( à vous de changer cela)
     
    			Connection connexion = DriverManager.getConnection("jdbc:mysql://localhost/membre","root","");
    			//Création de mon statement qui va me permettre d'executer mes requetes
    			Statement instruction = connexion.createStatement();
     
    			ResultSet resultat = instruction.executeQuery(requet);
     
    		}
    catch (Exception e){
     
    			System.out.println("echec pilote : "+e);
    		}
     
    	}
    et la page qui recupere le resultat de ma requete
    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
     
     
    if (e.getSource() == requete)
    		{
    			Fonction fonc = new Fonction();
    			String re = "SELECT nom FROM membres";
    			fonc.Conec(re);
     
     
    			//ResultSet resultat;
    			while( resultat.next())
    			{
     
     
    			}
    		}
    donc en fait mon probleme est que j'aimerai recuperer le resultat de type ResultSet, de ma classe de methode, dans mon autre classe afin de les afficher mais je ne sais pas comment faire pour recuperer ce resultat (while( resultat.next()) )


    si quelqu'un pourrait m'aider....

    merci d'avance

  2. #2
    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
    Points : 2 061
    Points
    2 061
    Par défaut
    bonjour,

    il suffit que ta methode "Conec" retourne un ResultSet a la place de void tous simplement
    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

  3. #3
    Membre confirmé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Points : 575
    Points
    575
    Par défaut
    ah oui d'accord!!

    donc si je fais ç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
    25
    26
     
     
    public ResultSet Conec (String requet)
     
    	{
     
    		String pilote = "com.mysql.jdbc.Driver";
     
    		try{
     
    			Class.forName(pilote);
    			Connection connexion = DriverManager.getConnection("jdbc:mysql://localhost/membre","root","");
    			Statement instruction = connexion.createStatement();
    			ResultSet resultat = instruction.executeQuery(requet);
    			return resultat;
     
    		}
    catch (Exception e){
     
    			System.out.println("echec pilote : "+e);
    		}
    		return null;
     
     
     
    	}
    c'est bon?

    Eclipse me dit d'ajouter le "return null" et je comprends pas pourquoi il me demande ça :s



    de 2, je fais ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if (e.getSource() == requete)
    		{
    			Fonction fonc = new Fonction();
    			String re = "SELECT nom FROM membres";
    			fonc.Conec(re);
    mais comment recuperer le "resultat" pour que je puisse faire ma boucle while

    merci encore de m'aider

  4. #4
    Membre confirmé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Points : 575
    Points
    575
    Par défaut
    j'ai fait ç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
     
    if (e.getSource() == requete)
    		{
    			Fonction fonc = new Fonction();
    			String re = "SELECT nom FROM membres";
    			ResultSet y = fonc.Conec(re);
     
     
     
     
    			try {
    				while( y.next())
    				{
     
     
    				}
    			} catch (SQLException e1) {
     
    				e1.printStackTrace();
    			}
    		}
    c'est bien ça?

  5. #5
    Membre confirmé Avatar de oceane751
    Profil pro
    Intégrateur Web
    Inscrit en
    Novembre 2004
    Messages
    1 280
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Intégrateur Web

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 280
    Points : 575
    Points
    575
    Par défaut
    ok c'est bon j'ai trouvé tt seul!!

    merci de m'avoir mis sur la voie!!!


  6. #6
    Membre averti
    Inscrit en
    Octobre 2007
    Messages
    311
    Détails du profil
    Informations forums :
    Inscription : Octobre 2007
    Messages : 311
    Points : 318
    Points
    318
    Par défaut
    Citation Envoyé par oceane751 Voir le message
    ah oui d'accord!!

    Eclipse me dit d'ajouter le "return null" et je comprends pas pourquoi il me demande ça :s
    Lorsque tu déclares une méthode non void, il faut absolument qu'elle retourne quelquechose. Or dans ton code, le "return resultat" est dans le bloc try/catch donc il y a une chance, si une erreur se produit, que tu n'arrives pas jusqu'au "return", donc que ta méthode ne renvoie rien. Le compilateur t'oblige donc à rajouter un "return" accessible (soit dans le "catch", soit après).


    Citation Envoyé par oceane751 Voir le message
    ok c'est bon j'ai trouvé tt seul!!

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

Discussions similaires

  1. Réponses: 9
    Dernier message: 18/08/2009, 14h20
  2. Réponses: 7
    Dernier message: 03/12/2008, 15h18
  3. Modifier une classe par une autre classe
    Par Couz02 dans le forum C++
    Réponses: 15
    Dernier message: 05/05/2008, 10h54
  4. Contrôle d'une fenêtre par une autre classe
    Par SuperWeight dans le forum Windows
    Réponses: 4
    Dernier message: 19/04/2007, 16h01
  5. Réponses: 3
    Dernier message: 30/03/2007, 10h38

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