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

JDBC Java Discussion :

Problème de navigation avec un Resultset


Sujet :

JDBC Java

  1. #1
    Membre habitué
    Profil pro
    Ingénieur informatique
    Inscrit en
    Avril 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur informatique

    Informations forums :
    Inscription : Avril 2006
    Messages : 166
    Points : 193
    Points
    193
    Par défaut Problème de navigation avec un Resultset
    Bonjour,

    Je suis face à un problème qui me tient en échec depuis hier.
    J'implémente une méthode pour pourvoir effectuer une requête SELECT pour récupérer des informations présente dans une base de données de type ORACLE XE 10g.

    Voici la fonction Select en question:
    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
     
    public Vector<Vector<String>> Select2(String tab,Vector<String> SelField,String WhereField,String arg) throws SQLException
    	{
    		//Declarations
    		String req, FSel = null;
    		Vector<Vector<String>> result = null;
    		int i = 0;
     
    		//Format string for request
    		FSel = SelField.elementAt(0);
    		for (i=1;i<SelField.size();i++)
    		{
    			FSel = FSel + "," + SelField.elementAt(i);
    		}
     
    		//Execute request
    		stmt = con.createStatement();
     
    		req = "SELECT " + FSel + " FROM " + tab + " WHERE " + WhereField + " like " + arg;
    		System.out.println(req); //TODO Affiche la requête envoyée dans la console
    		res = stmt.executeQuery(req);
     
    		//Get request Result
    		result = getData(SelField);
     
    		return result;
    	}
    Pour récupérer les données générées par cette requête j'utilise une autre méthode : getData.

    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
     
        public Vector<Vector<String>> getData(Vector<String> fields)
    	{
    		int nbFields = 0;
    		int i = 0,pos = 0;
    		boolean test = true;
    		Vector<String> row = new Vector<String>();
    		Vector<Vector<String>> tab = new Vector<Vector<String>>();
     
    		nbFields = fields.size();
     
            try
    	    {
     
                //res.first();
     
    		    while (test)
    		    {
                    row = new Vector<String>();
                    for (i=0;i<nbFields;i++)
    			    {
                        pos = res.findColumn(fields.elementAt(i));
    			    	row.add(res.getString(pos));
    			    }
     
    			    tab.add(row);
     
    			    test = res.next();
    		    }
    		}
            catch(SQLException evt)
    		{
            	System.out.println(evt.getErrorCode());
            	System.out.println(evt.getMessage());
    		}
     
    		return tab;
    	}
    Tous mes problèmes viennent de cette dernière méthode.

    Si j'enlève les commentaires de j'obtiens
    Opération non valide sur un ensemble de résultats de type forward-only : first
    et si je laisse cette instruction commentée j'obtiens comme message d'erreur
    ResultSet.next n'a pas été appelé
    .

    Pour information, la requête injectée dans la base de données fonctionne (testé avec SQL Command de Oracle) et ces méthodes marchent très bien si la base de données est MySQL.

    Merci d'avance pour votre aide!!

  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,

    En fait, ton problème viens du fait que tu as un resultSet de type TYPE_FORWARD_ONLY ce qui signifie que tu ne peux pas effectuer de first() et previous(). Normalement si tu lis les éléments du premier vers le dernier seul la methode next est utile.

    La mehtode doit etre ecrite de la facon suivante :
    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
    public Vector<Vector<String>> getData(Vector<String> fields)
    	{
    		int nbFields = 0;
    		int i = 0,pos = 0;
    		boolean test = true;
    		Vector<String> row = new Vector<String>();
    		Vector<Vector<String>> tab = new Vector<Vector<String>>();
     
    		nbFields = fields.size();
     
            try
    	    {
     
                   while (res.next())
    		    {
                    row = new Vector<String>();
                    for (i=0;i<nbFields;i++)
    			    {
                        pos = res.findColumn(fields.elementAt(i));
    			    	row.add(res.getString(pos));
    			    }
     
    			    tab.add(row);
    		    }
    		}
            catch(SQLException evt)
    		{
            	System.out.println(evt.getErrorCode());
            	System.out.println(evt.getMessage());
    		}
            
    		return tab;
    	}
    Maintenant si tu vraiment besoin d'appeler ces methodes du doit créer ton statement de la facon suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    stmt = con.createStatement(ResultSet.TYPE_SCROLL_INSENSITIVE, ResultSet.CONCUR_READ_ONLY);
    Cependant, attention car le fait que tu effectues cette action aura un impacte sur les perfs
    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 habitué
    Profil pro
    Ingénieur informatique
    Inscrit en
    Avril 2006
    Messages
    166
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur informatique

    Informations forums :
    Inscription : Avril 2006
    Messages : 166
    Points : 193
    Points
    193
    Par défaut
    Un grand merci à toi Alkhan! J'ai appliqué ton code et ça marche parfaitement (enfin seulement le premier j'ai gardé le statement tel quel)...

    Encore Merci!!

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

Discussions similaires

  1. Problème de navigation rule avec JSF
    Par anapotheque dans le forum JSF
    Réponses: 6
    Dernier message: 23/07/2010, 12h07
  2. [AJAX] lightbox avec une navigation en ajax
    Par negurah dans le forum AJAX
    Réponses: 1
    Dernier message: 25/08/2009, 13h21
  3. Problème de navigation rule avec tomcat
    Par troubleshooting dans le forum JSF
    Réponses: 7
    Dernier message: 17/06/2009, 16h16
  4. Problème de page blanche sur navigation avec html:link
    Par assistibm dans le forum Struts 1
    Réponses: 7
    Dernier message: 13/07/2007, 13h31
  5. Problème de navigation réalisé avec CSS
    Par Mihai dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 18/09/2005, 18h51

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