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 :

j'arrive pas a garder la valeur


Sujet :

JDBC Java

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    506
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 506
    Par défaut j'arrive pas a garder la valeur
    bonjour ,

    je n'arrive pas a garder le resultat de mon idclient :

    lorsque je valide ma premiere ihm il me marque exemple 30 mais losque je veux l'utiliser il me marque 0 pourquoi voici mon code

    code on j'ai initialiser idclient :
    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
    public class Fenetre extends JFrame implements ActionListener{
     
    	private Fenetre client;
     
     
    	private JTextField   Text_nom_entreprise;
    	private JTextField   Text_activite;
    	private JTextField   Text_adresse;
    	private JTextField   Text_ville;
    	private JTextField   Text_code_postal;
    	private JTextField   Text_pays;
     
     
    	private int idclient=0;
     
     
    	private JTextField textnomclient;
    le code de mon programme :
    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
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    public void actionPerformed(ActionEvent e) {
     
    		if(e.getSource()==valider_entreprise)
    		{ 
     
     
     
    			try{
    				Class.forName("com.mysql.jdbc.Driver");
    				System.out.println("JDBC Load ok");
    			}
    			catch (ClassNotFoundException e1)
    			{
    				System.out.println (e1);
    			}
     
     
    			int cod = Integer.parseInt(Text_code_postal.getText());
    			System.out.println(idclient);
     
    			 try{
    				 java.sql.Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/Ecommerce","root","");
    				 System.out.println("bonne connexion");
     
                     String sqle="INSERT INTO Entreprise (identreprise,idclient,nomentreprise,activite,adresseentreprise,villeentreprise,codepostaleentreprise,paysentreprise)"+
    				 "values("+"NULL,"+idclient+",'"+Text_nom_entreprise.getText()+"','"+Text_activite.getText()+"','"+Text_adresse.getText()+"','"+
    				 Text_ville.getText()+"',"+cod+",'"+Text_pays.getText()+"')";
     
    				 PreparedStatement pr=conn.prepareStatement(sqle);
    				 pr.executeUpdate(sqle);
     
     
    				 pr.close();
    				 conn.close();
    				 System.out.println("enrengistrement entreprise reussi !!");
     
     
    		}catch (SQLException e2)
    		{
    			System.out.println(e2);
    		}	
     
    			return;
     
    		}
     
     
     
     
     
    		if (e.getSource()==butihmclientannuler)
    		{
    			textnomclient.setText("");
    			textprenom.setText("");
    			textadresse.setText("");
    			  textville.setText("");
    			textcode.setText("");
    			 textcode.setText("");
    			 textpays.setText("");
    			textpseudo.setText("");
    			textpass.setText("");
    			textmail.setText("");	
    			return;
    		}
     
     
     
    		 if (e.getSource()== butihmclientvalider);
    		{int idclient;
     
    			try{
    				Class.forName("com.mysql.jdbc.Driver");
    				System.out.println("JDBC Load ok2");
    			}
    			catch (ClassNotFoundException e1)
    			{
    				System.out.println (e1);
    			}
     
    			System.out.println("ok");
     
    			if (textnomclient.getText().equals("")||textnomclient.getText()==null||textprenom.getText().equals("")||textprenom.getText()==null||textadresse.getText().equals("")
                    ||textadresse.getText()==null||textville.getText()==null||textville.getText().equals("")||textcode.getText().equals("")||textcode.getText()==null||textpays.getText().equals("")||
                    textpays.getText()==null||textpseudo.getText().equals("")||textpseudo.getText()==null||textpass.getText().equals("")||textpass.getText()==null||textmail.getText().equals("")||
                    		textmail.getText()==null)	{
    				System.out.println("erreur lors de l'inialisation");
    			}
    			else
    			{
    			nom =textnomclient.getText();
    			prenom =textprenom.getText();
    			 adresse =textadresse.getText();
    			 ville = textville.getText();
    			 Code =textcode.getText();
    			 code =Integer.parseInt(Code);
    			 pays =textpays.getText();
    			 pseud =textpseudo.getText();
    			 pass =textpass.getText();
    			 mail =textmail.getText();
     
    			 try{
    				 java.sql.Connection con = DriverManager.getConnection("jdbc:mysql://localhost/Ecommerce","root","");
    				 System.out.println("bonne connexion");
     
    				 String sq="Select nom,prenom from Client";
     
     
     
    				 Statement st =con.createStatement();
    				 ResultSet re =st.executeQuery(sq);
    				 if (re.next())
    				 {
    					 if (re.getString("nom").equals(textnomclient.getText())&&re.getString("prenom").equals(textprenom.getText()))
    					 {
     
    						re.close();
    						st.close();
    						con.close();
    						System.out.println("la personne existe ");
    						return;
    					 }
    					 else
    					 {
     
     
    				 String  sql="INSERT INTO Client (idclient,nom,prenom,adresse,ville,codepostale,pays,pseudo,password,email)"+
    			     "values("+"NULL,'"+textnomclient.getText()+"','"+textprenom.getText()+"','"+adresse+"','"+ville+"',"+code+
    			     ",'"+pays+"','"+pseud+"','"+pass+"','"+mail+"')";
     
    			     PreparedStatement s =con.prepareStatement(sql);
     
     
    			s.executeUpdate(sql);
     
     
    					s.close();
     
     
     
    					 System.out.println("execution ok");
     
    					 String sqlc ="select idclient from Client where nom='"+textnomclient.getText()+"'";
    			           Statement sta =con.createStatement();
    			           res= sta.executeQuery(sqlc);
     
    			           System.out.println("transmission ok");
     
    			           if (res.next())
    			           {
    					 idclient= res.getInt("idclient");
    					 System.out.println(idclient);
    			           }
    			           res.close();
    			           sta.close();
    			           con.close();
    			           return;
    					 }  
     
    				 }
     
     
     
     
    			 }catch(SQLException e2)
    			 {
    				 System.out.println( e2.toString());
    			 }
     
    		}
     
    		}
    		// TODO Auto-generated method stub
     
    	}

    merci !

  2. #2
    Rédacteur
    Avatar de eclesia
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    2 111
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 111
    Par défaut
    remplace deja ca :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    if(e.getSource()==valider_entreprise)
    par
    if(e.getSource().equals(valider_entreprise))
    le == c'est pour les variables. le equals pour les objects.

    ensuite :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     String sqle="INSERT INTO Entreprise (identreprise,idclient,nomentreprise,activite,adresseentreprise,villeentreprise,codepostaleentreprise,paysentreprise)"+
    				 "values("+"NULL,"+idclient+",'"+Text_nom_entreprise.getText()+"','"+Text_activite.getText()+"','"+Text_adresse.getText()+"','"+
    				 Text_ville.getText()+"',"+cod+",'"+Text_pays.getText()+"')";
    a tout hasard :
    tu ne mets pas de quote pour le idclient, vérifis qu'il s'agit bien d'un numerique dans ta table.


    dans la suite de ton code tu fais les tests avec des "if", mets plutot des "else if" car il ne peut pas y avoir 2 solutions en meme temps.

  3. #3
    Rédacteur
    Avatar de eclesia
    Profil pro
    Inscrit en
    Décembre 2006
    Messages
    2 111
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2006
    Messages : 2 111
    Par défaut
    j'oublis le principal :

    ton probleme vient peut etre de ta base, si elle est bien faites tu dois avoir une liaison entre id_client et une autre table, vérifis que ta valeur id_client est bien presente dans l'autre table.

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    506
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 506
    Par défaut
    ça ne fonctionne toujours pas :

    ma base de donnee :

    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
    create table Client (
                  idclient INTEGER(10) PRIMARY KEY,
                  nom CHAR(40),
                  prenom CHAR(40),
                  adresse CHAR(100),
                  ville CHAR(50),
                  codepostale INTEGER(5),
                  pays CHAR(40),
                  pseudo CHAR(30),
                  password CHAR(30,
                  email CHAR(50),
                  ))
     
    create table Entreprise (
              identreprise INTEGER(10) PRIMARY KEY,
              idclient INTEGER(10),  
              nomentreprise CHAR(40),
              activite CHAR(50),
              adresseentreprise CHAR(100),
              villeentreprise CHAR(50),
              codepostaleentreprise INTEGER(5),
              paysentreprise CHAR(40))


    lorsque je programme :

    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
    String sqlc ="select idclient from Client where nom='"+textnomclient.getText()+"'";
    			           Statement sta =con.createStatement();
    			           res= sta.executeQuery(sqlc);
     
    			           System.out.println("transmission ok");
     
    			           if (res.next())
    			           {
    					 idcliente= res.getInt("idclient");
    					 System.out.println(idcliente);
    			           }
    			           res.close();
    			           sta.close();
    			           con.close();
    			           return;
    					 }
    idcliente me marque par exemple le 30 eme client : 30

    lorsque je le reutilise dans ce programme :
    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
    int cod = Integer.parseInt(Text_code_postal.getText());
    			System.out.println(idcliente);
     
     
     
     
     
     
     
     
     
    			 try{
    				 java.sql.Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/Ecommerce","root","");
    				 System.out.println("bonne connexion");
     
     
     
                     String sqle="INSERT INTO Entreprise (identreprise,idclient,nomentreprise,activite,adresseentreprise,villeentreprise,codepostaleentreprise,paysentreprise)"+
    				 "values("+"NULL,"+idcliente+",'"+Text_nom_entreprise.getText()+"','"+Text_activite.getText()+"','"+Text_adresse.getText()+"','"+
    				 Text_ville.getText()+"',"+cod+",'"+Text_pays.getText()+"')";
     
    				 PreparedStatement pr=conn.prepareStatement(sqle);
    				 pr.executeUpdate(sqle);
     
     
    				 pr.close();
    				 conn.close();
    				 System.out.println("enrengistrement entreprise reussi !!");
     
     
    		}catch (SQLException e2)
    		{
    			System.out.println(e2);
    		}	
     
    			return;
     
    		}
    idcliente me marque 0 pourquoi comme si il n'avait pas pris la valeur 30 ???


    merci !

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2003
    Messages
    506
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2003
    Messages : 506
    Par défaut
    j'ai reussi a garder la valeur :

    en me reveillant ce matin ,la solution m'est venu directement : il faut mettre un static a la variable idcliente:

    private static int cliente;



    merci !

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

Discussions similaires

  1. Je n'arrive pas a modifier les valeurs de mon tableau via mon UserForm
    Par Patouillou dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 24/02/2015, 16h15
  2. J'arrive pas a recupére une valeur decimale d'un msflexgrid
    Par charifclub dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 06/06/2013, 00h33
  3. Réponses: 17
    Dernier message: 20/06/2007, 14h54
  4. [C#] Je n'arrives pas a récuperer la valeur de retour de ma requete
    Par Cazaux-Moutou-Philippe dans le forum Windows Forms
    Réponses: 8
    Dernier message: 23/06/2006, 14h25
  5. Réponses: 9
    Dernier message: 20/06/2006, 18h47

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