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 :

inserer le contenu d'un textField vers une base de données sql


Sujet :

JDBC Java

  1. #1
    Membre du Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2016
    Messages
    75
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Maroc

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Janvier 2016
    Messages : 75
    Points : 50
    Points
    50
    Par défaut inserer le contenu d'un textField vers une base de données sql
    bonsoir a tous

    Je voudrai inserer des donnèes reccuperèe a partir d'un TextField vers ma base de donnèes
    voici le code que j'ai faite :

    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
     
    try {
                    Class.forName("com.mysql.jdbc.Driver");
     
                    connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/phone" ,"root","");
                    statement = connection.createStatement();
     
                    String requete="INSERT INTO historique(durèe,coût) VALUES (' duree.getText() ',' total.getText()')";
    		statement.executeUpdate(requete);
     
     
     
     
                    } catch (ClassNotFoundException | SQLException ex) {
                        System.err.println(ex.getMessage());
                    }
    ca s'ajoute a la base de donnèes mais comme ca :

    Nom : Capture.PNG
Affichages : 1251
Taille : 14,4 Ko

    moi je voudrai insérer les valeurs contenue dans les Txtfield..
    merci pour votre aide..

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String requete="INSERT INTO historique(durèe,coût) VALUES (' duree.getText() ',' total.getText()')";
    Je ne vois pas ce qui t'étonne : ce qu'il y a entre " est la requête qui est envoyée au sgbd qui l'exécute et qui n'a aucun accès à ton programme d'une part, et qui n'a aucune raison d'interpreté des bouts de Java !
    C'est comme que si tu écris :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    System.out.println("INSERT INTO historique(durèe,coût) VALUES (' duree.getText() ',' total.getText()')";
    ça va afficher exactement cette chaine : il n'y aura pas d'exécution du code Java entre les ".

    Il faut récupérer les valeurs dans les champs et les concaténer dans la requête !
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String requete="INSERT INTO historique(durèe,coût) VALUES ('"+ duree.getText() + "','"+ total.getText() +"')";
    Mais la bonne manière de faire est d'utiliser un PreparedStatement : déjà ça va te simplifier la problématique des quotes (parce que n'oublie pas qu'on peut saisir des quotes dans des champs de saisie) et des dates aussi le cas échéant, et c'est plus sécurisé (empêche l'injection SQL).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    PreparedStatement statement = connection.prepareStatement("INSERT INTO historique(durèe,coût) VALUES ( ?, ?)");
     
    statement.setString( 1, duree.getText() );
    statement.setString( 2, total.getText() );
     
    statement.executeUpdate();
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

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

Discussions similaires

  1. Connecter vers une base de donnée SQL Server via Internet
    Par ArtherKing dans le forum Administration
    Réponses: 1
    Dernier message: 22/07/2015, 10h13
  2. inserer le contenu d'un JTextArea dans une base de données
    Par samarqand dans le forum Composants
    Réponses: 2
    Dernier message: 24/06/2015, 23h58
  3. Réponses: 6
    Dernier message: 18/02/2011, 17h21
  4. Réponses: 3
    Dernier message: 16/07/2009, 18h00
  5. java+mettre le contenu d'un TextField ds une base de données
    Par Fredo le Tsar dans le forum Access
    Réponses: 1
    Dernier message: 20/05/2006, 18h29

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