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 d'une mise à jour de table


Sujet :

JDBC Java

  1. #1
    Membre à l'essai
    Inscrit en
    Juin 2013
    Messages
    29
    Détails du profil
    Informations forums :
    Inscription : Juin 2013
    Messages : 29
    Points : 23
    Points
    23
    Par défaut Problème d'une mise à jour de table
    Bonsoir , j'ai besoin de faire un UPDATE d'une table à partir de java mais j'ai pas peut être (ou surement ) bien connu la requête adéquate , en effet je veux soustraire le un nombre entier à un contenu d'une colonne (entier aussi ) voici le code que j'ai essayé mais ca marche pas , j'ai une erreur dans sql :

    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
    try(){
     
    String a=Combo1.getSelectedItem().toString();
    int b =(Integer)jSpinner1.getValue();
    String c  = ((JTextField)jcal.getDateEditor().getUiComponent()).getText();  
    int f = -b ;
     
         if(evt.getSource()==btn_cmd)
          {
          try{
     
                Connection conn; 
                Class.forName("com.mysql.jdbc.Driver");
                conn=DriverManager.getConnection("jdbc:mysql://localhost:3306/stage","root","admin");
     
                Statement pst=conn.createStatement();
               Statement pst2=conn.createStatement();
     
                pst.executeUpdate("INSERT INTO Commande(Nom_article,Qté_commande,Date_commande) values ('"+a+"','"+b+"','"+c+"')");
                pst.executeUpdate("UPDATE Commande SET Qté_dispo =Qté dispo +"+f+" WHERE Nom_article='"+a+"'");
                JOptionPane.showMessageDialog(null , "Commande envoyé","Accusé !",
                                            JOptionPane.INFORMATION_MESSAGE); 
                    setVisible(false) ;
     
               }catch (Exception e) 
            {
                System.out.println(e);
            }
     
          }
        }

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2008
    Messages
    394
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2008
    Messages : 394
    Points : 639
    Points
    639
    Par défaut
    Bonjour,

    Cette ligne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    pst.executeUpdate("UPDATE Commande SET Qté_dispo =Qté dispo +"+f+" WHERE Nom_article='"+a+"'");
    est incorrecte. La variable que j'ai mise en rouge est mal nommée tu as mis un espace au lieu d'un "_" :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    pst.executeUpdate("UPDATE Commande SET Qté_dispo =Qté_dispo +"+f+" WHERE Nom_article='"+a+"'");
    A ta place j'éviterais aussi les accents dans les noms de variables, tu risques d'avoir des erreurs incompréhensibles... Aussi je te conseille d'utiliser des PreparedStatement pour des questions de robustesse et sécurité.

    Romain.

  3. #3
    Rédacteur/Modérateur
    Avatar de andry.aime
    Homme Profil pro
    Inscrit en
    Septembre 2007
    Messages
    8 391
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Ile Maurice

    Informations forums :
    Inscription : Septembre 2007
    Messages : 8 391
    Points : 15 059
    Points
    15 059
    Par défaut
    Bonjour,

    Utilise un PreparedStatement mais ne met pas les valeurs en dur dans la requête.

    A+.

Discussions similaires

  1. comment faire une Mise à jour de table de fait ?
    Par jerada dans le forum Développement de jobs
    Réponses: 1
    Dernier message: 29/12/2011, 12h02
  2. Détection d'une mise à jour de table
    Par lodan dans le forum Requêtes
    Réponses: 12
    Dernier message: 11/05/2011, 09h24
  3. Problème avec une mise à jour
    Par michelp3 dans le forum Windows Vista
    Réponses: 0
    Dernier message: 08/01/2010, 15h26
  4. Réponses: 1
    Dernier message: 08/07/2009, 11h52
  5. Problème d'une mise à jour
    Par Hamdi dans le forum Access
    Réponses: 2
    Dernier message: 17/09/2005, 13h57

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