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 lors d'une insertion


Sujet :

JDBC Java

  1. #1
    Nouveau candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2014
    Messages
    1
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Burkina Faso

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2014
    Messages : 1
    Par défaut Problème lors d'une insertion
    Bonjour à tous,

    Je me suis inspiré des différents tutoriels sur internet pour mettre en place un programme qui depuis une interface permet d’insérer des données pour un utilisateur. Mon problème c'est que depuis quelques jours j'ai l'erreur suivante :
    [Microsoft][ODBC Microsoft Access Driver]Syntaxe error in INSERT INTO statement
    J'ai cette erreur qui s'affiche et je ne comprend pas trop pourquoi. C'est mon premier programme en java et j'ai vraiment besoin d'aide :
    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
    private void validerActionPerformed(java.awt.event.ActionEvent evt) {                                        
            // TODO add your handling code here:
     
             try{
                Class.forName("sun.jdbc.odbc.JdbcOdbcDriver");
                conx=DriverManager.getConnection("jdbc:odbc:Database1");
     
                String sql="insert into Donnee(Titre,Login,Pswd,Url,Note,IdUtilisateur) values(?,?,?,?,?,?)";[/B]
     
                pst = conx.prepareStatement(sql);
     
                 if(ttre.getText().isEmpty() || titre.getText().isEmpty() || pass1.getText().isEmpty() || pass.getText().isEmpty()||util.getText().isEmpty()){
                         JOptionPane.showMessageDialog(null, "Veillez Remplir les Champs");
                        }
                            else{
                            if(pass1.getText().matches(pass.getText()))
                            {
                                pst.setString(1, ttre.getText());
                                pst.setString(2, util.getText());
                                pst.setString(3, pass1.getText());
                                pst.setString(4, titre.getText());
                                pst.setString(5, note.getText());
                                pst.setInt(6, idutilisateur);
                                System.out.println("remplcement des variable ensuite execution de la requete");
     
     
                                if(JOptionPane.showConfirmDialog(null,"Ajouter Donnee ?","Confirmer Ajout",JOptionPane.YES_NO_OPTION)==JOptionPane.OK_OPTION)
                                 {
                                    pst.executeUpdate();
                                  ;
                                    JOptionPane.showMessageDialog(null, "Donnee enregistree");
                                    new fenetre2().setVisible(true);
                                    this.dispose();
                                }
     
                            }
                            else{
                                JOptionPane.showMessageDialog(null, "Mot de passe 1 et 2 non identique");
                            }}
     
                    }catch(SQLException e){
                            JOptionPane.showMessageDialog(this, "la donnee n'a pas ete ajoutee \n"+e.getMessage());
     
                        } catch (ClassNotFoundException ex) { 
                        Logger.getLogger(NewJFrame.class.getName()).log(Level.SEVERE, null, ex);
     
            } 
     
     
        }
    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
    Quand tu dis : "depuis quelques jours ..."
    est-ce que cela fonctionnait avant ?

    Si oui, est-ce que la structure de la table "Donnee" a changé ?
    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
    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
    Citation Envoyé par toufik.dija Voir le message
    Bonjour,

    a mon avis il faut que vous faites

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    String requete = "votre requete ici";
    ResultSet rs = sta.executeQuery(requete);
    j'espere que ça va aider
    Ben non, parce que là tu lui indique comment récupérer un jeu d'enregistrements (ResultSet )
    Alors que sa requête est une requête qui exécute une action : "INSERT INTO ...."
    et qui ne renvoie donc rien du tout.
    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/

  4. #4
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2013
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 43
    Par défaut
    ah oui c'est vrai je suis désolé

    il faut faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     statement.executeUpdate("INSERT INTO Table" + "VALUES (?, ?, ?)");
    ???
    ou bien je me trompe aussi

  5. #5
    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
    Citation Envoyé par toufik.dija Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     statement.executeUpdate("INSERT INTO Table" + "VALUES (?, ?, ?)");
    ???
    c'est déjà l'instruction qu'il utilise à la ligne 29 de son code !
    executeUpdate est appliqué à son PreparedStatement
    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/

  6. #6
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2013
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 43
    Par défaut
    Citation Envoyé par Népomucène Voir le message
    c'est déjà l'instruction qu'il utilise à la ligne 29 de son code !
    executeUpdate est appliqué à son PreparedStatement

    oui mais normalement c'est ça non??

  7. #7
    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
    @Toufik, reprend la documentation JDBC et ne suggère une réponse que quand tu es sûr de toi.
    Konate a besoin de résoudre son problème alors que son code est apparemment correct.

    De surcroît, le message d'erreur est "Syntax error in INSERT INTO statement"
    ce qui est un message ODBC Access et non pas Java.
    Il ne sert donc à rien de regarder du côté de la syntaxe JDBC.
    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/

  8. #8
    Membre actif
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2013
    Messages
    43
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2013
    Messages : 43
    Par défaut
    Entendu

Discussions similaires

  1. [XL-2010] Problème lors d'une insertion dans une table
    Par juju05 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 01/06/2015, 09h53
  2. Problème lors d'une insertion avec QSqlRelationalTableModel
    Par Action Fighter dans le forum Bases de données
    Réponses: 2
    Dernier message: 13/04/2011, 10h45
  3. Problème lors d'une insertion de page
    Par tomividad dans le forum VBA Word
    Réponses: 1
    Dernier message: 20/03/2009, 16h43
  4. Réponses: 2
    Dernier message: 20/10/2005, 10h50
  5. [JDesktopPane] Problème lors de l'insertion d'une JInternalFrame
    Par Invité dans le forum Agents de placement/Fenêtres
    Réponses: 5
    Dernier message: 21/09/2005, 01h38

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