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 :

Java et BDD Postgresql : problème de modification de table


Sujet :

JDBC Java

  1. #1
    Membre averti
    Femme Profil pro
    Étudiant
    Inscrit en
    Janvier 2012
    Messages
    24
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2012
    Messages : 24
    Par défaut Java et BDD Postgresql : problème de modification de table
    Bonsoir a tous,

    J'ai une classe qui me permet de modifier un enseignant mais au moment ou je clique sur l'enseignant a modifier il me renvoi comme erreur :
    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
     
    IWAV0048I Java Bean modifier_enseig started with null constructor
    5
    java.lang.reflect.InvocationTargetException
    	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    	at sun.reflect.NativeConstructorAccessorImpl.newInstance(Unknown Source)
    	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(Unknown Source)
    	at java.lang.reflect.Constructor.newInstance(Unknown Source)
    	at org.eclipse.ve.internal.java.vce.launcher.remotevm.JavaBeansLauncher.main(JavaBeansLauncher.java:86)
    Caused by: org.postgresql.util.PSQLException: Le ResultSet n'est pas positionné correctement, vous devez peut-être appeler next().IWAV0052E Invocation Target Exception creating modifier_enseig
     
    	at org.postgresql.jdbc2.AbstractJdbc2ResultSet.checkResultSet(AbstractJdbc2ResultSet.java:2695)
    	at org.postgresql.jdbc2.AbstractJdbc2ResultSet.getString(AbstractJdbc2ResultSet.java:1872)
    	at modifier_enseig.<init>(modifier_enseig.java:69)
    	... 5 more
    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
    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
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
     
    import java.awt.BorderLayout;
    import java.awt.Component;
    import java.sql.PreparedStatement;
    import java.sql.ResultSet;
    import java.sql.ResultSetMetaData;
    import java.sql.SQLException;
    import java.sql.Statement;
     
    import javax.swing.*;
    import javax.swing.table.DefaultTableCellRenderer;
    public class modifier_enseig {
     
     
     
    	public modifier_enseig() throws SQLException {
     
    		Statement state = Connect.getInstance()
    		.createStatement(
    					ResultSet.TYPE_SCROLL_INSENSITIVE, 
    					ResultSet.CONCUR_READ_ONLY
    		);
    		ResultSet res = state.executeQuery("SELECT num_ensig,nom FROM enseignant");
     
     
     
     
     
    		res.last();
    		int rowCount = res.getRow();
    		System.out.println(rowCount);
     
    		res.beforeFirst();
    		Object[] data = new Object[rowCount];
     
    		int i=0;
    		while(res.next()){
     
    				data[i] = res.getString("num_ensig")+" > "+res.getString("nom");
     
    	i++;
     
    		}
     
     
     
     
     
     
     
     
    	JOptionPane jop = new JOptionPane(), jop2 = new JOptionPane();
    	ImageIcon img = new ImageIcon("images/admin.jpg");
    	String modele = (String)jop.showInputDialog(null, 
    									"Veuillez choisir le num d'enseignant a modifier !",
    									"Modification d'un enseig !",
    									JOptionPane.QUESTION_MESSAGE,
    									img,
    									 data,
    									null);
     
    	//PreparedStatement prepare = Connect.getInstance().prepareStatement("UPDATE professeur set prof_prenom = ? WHERE prof_nom = 'MAMOU'");
    try{
        String[] str = modele.split("\\ > ");
     
    	res = state.executeQuery("SELECT * FROM enseignant WHERE num_ensig= '"+str[1]+"' ");
     
    	res.first();
    	res.next()
    //ici la ligne 69 qui est renvoyé au niveau des erreur! mais je sais pas //pourquoi???
    	String num_ensig = res.getString("num_ensig");
    	String nom = res.getString("nom");
    	String prenom = res.getString("prenom");
    	String grade = res.getString("grade");
    	String mail = res.getString("mail");
    	//int id = res.getInt("id");
     
    	System.out.println(nom);
     
    	String prenom1 = res.getString("prenom");
    	ajouter_enseig a = new ajouter_enseig (num_ensig,nom,prenom,grade,mail);
    	ajouter_enseig  zd = new ajouter_enseig (null, "Modifier un enseignant", true);
    }catch(NullPointerException e) {}
     
    	res.close();
    	state.close();
     
     
     
    	}
     
     
    }
    Est ce que quelqu'un peut me dire ou est le conflit !

    Merci d'avance

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 713
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Développeur java, access, sql server
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2005
    Messages : 2 713
    Par défaut
    la documentation de la méthode "first()" du RecordSet dit :
    Moves the cursor to the first row in this ResultSet object
    ce qui veut dire que tu es sur la 1ère ligne de résultats.

    Donc si tu places une méthode "next()" juste après alors qu'à l'évidence
    il n'y a qu'un seul enregistrement
    et bien tu tombes dans le vide ...
    Labor improbus omnia vincit un travail acharné vient à bout de tout - Ambroise Paré (1510-1590)

    Consulter sans modération la FAQ ainsi que les bons ouvrages : http://jmdoudoux.developpez.com/cours/developpons/java/

  3. #3
    Membre averti Avatar de NRLinker
    Homme Profil pro
    Développeur Java
    Inscrit en
    Juin 2012
    Messages
    44
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Juin 2012
    Messages : 44
    Par défaut
    C'est puisque il ya rien dans l'emplacement ou tu mets ton curseur . Si tu veux récuperer (modifier ) que le premier élémenet essayes faire plutôt if ( res.first() ) puis ton traitement au lieu de faire first () puis next () . puisque effectivement cela te fais tomber dans le vide .

Discussions similaires

  1. Problème de modification de tables via un formulaire
    Par maxmusix dans le forum VBA Access
    Réponses: 1
    Dernier message: 27/05/2013, 16h08
  2. Réponses: 7
    Dernier message: 15/06/2011, 11h26
  3. JSP + JAVA problème insertion dans ma table postgresql
    Par stikmou dans le forum Servlets/JSP
    Réponses: 9
    Dernier message: 05/01/2011, 10h55
  4. [ POSTGRESQL ] Problème de performance
    Par Djouls64 dans le forum PostgreSQL
    Réponses: 6
    Dernier message: 26/05/2003, 16h18
  5. [PostgreSql] Problème de cadreage de char !!!
    Par moipastoi dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/05/2003, 18h01

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