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 :

Récupérer un donnée à partir d'une BDD et l’affecter dans une variable String


Sujet :

JDBC Java

  1. #1
    Futur Membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juin 2014
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Juin 2014
    Messages : 4
    Points : 6
    Points
    6
    Par défaut Récupérer un donnée à partir d'une BDD et l’affecter dans une variable String
    Bonjour,

    Je travaille actuellement sur une petite application desktop (gestion de stock ), la connexion avec la base ça marche nickel. J'ai déjà fait un teste d'insertion dans ma BDD (une base crée avec phpmyadmin(wampserver) ), aussi la récupération des données et les afficher dans un JTable .

    Mon problème consiste a faire une interface d'Authentification ( user , mdp + bouton) voici le 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
        private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                         
            Menu Appel = new Menu(); ////  c'est la page que jveu rediriger le user !
            String  ID    = JTID.getText();
            String  PASSE = JTPASS.getText();
     
            String RequeteAuthentIfication="select * from sécurité where (user = '"+ID+"' and passe '"+PASSE+"')";          
            try 
                 {  
                    stmtAuthentification= maconnexion.ObtenirConexion().createStatement();           //
                    ResultSet resultat = stmtAuthentification.executeQuery(RequeteAuthentIfication);//
     
                    while(resultat.next())
                    {
                    String IDD  =resultat.getString("user") ;
                    String PASS =resultat.getString("pass");
                    System.out.println(""+IDD+""+PASS+"");// pour voir quand sa fonction
                    if (IDD.equals(ID))
                      acée=1; else acée=0;   
                    }
                 }
            catch(SQLException ex)
                 {  System.out.println(ex);
                 }
            if ( acée==1) Appel.setVisible(true); // rendre le JFRame ou je veu allé visible !
        }
    Lla description de l'erreur :
    chargement du pilote reussie
    connexion a la base de données reussie
    com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''sos')' at line 1
    PS : si vous aviez une meilleur idée je suis preneur

  2. #2
    Modérateur

    Homme Profil pro
    Développeur java, access, sql server
    Inscrit en
    Octobre 2005
    Messages
    2 710
    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 710
    Points : 4 794
    Points
    4 794
    Par défaut
    C'est une erreur dans la requête sql :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "select * from sécurité where (user = '"+ID+"' and passe '"+PASSE+"')";
    s'il y a une apostrophe dans ID ou dans passe alors ça ne marche pas.

    Utilise toujours un PreparedStatement plutôt qu'un Statement.
    le PreparedStatement s'occupe des apostrophes, variables numériques, dates et autres bidules casse-pieds et bugophiles.

    Par ailleurs, MySql, selon la version, est souvent fâché avec les accents dans les noms de table/champ/requête.
    il est possible que le nom "sécurité" avec accent ne passe pas.
    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 expérimenté Avatar de Nico02
    Homme Profil pro
    Developpeur Java/JEE
    Inscrit en
    Février 2011
    Messages
    728
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Developpeur Java/JEE
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2011
    Messages : 728
    Points : 1 622
    Points
    1 622
    Par défaut
    Salut,

    Bon dans un premier temps je pense qu'une simple lecture de l'erreur peut te mettre sur la voie.

    You have an error in your SQL syntax
    ça me parait assez clair. Maintenant reste à savoir pourquoi.

    Déjà, il est plus que déconseillé d'utiliser des caractères spéciaux dans le nom d'une table (ou nulle part d'ailleur), 'sécurité' est donc à proscrire.

    Ensuite pour éviter ce genre d'erreurs de syntaxe (en plus te t'avoir pleins d'autres avantages) quand tu passes des paramètres dans une requête, le plus simple reste d'utiliser un PreparedStatement à la place du Statement traditionnel.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    PreparedStatement pstmt = con.prepareStatement("SELECT * FROM SECURITE WHERE user = ? AND pass = ?");
       pstmt.setString(1, ID);
       pstmt.setString(2, PASSE);
       ResultSet resultat = pstmt.executeQuery();

Discussions similaires

  1. Réponses: 1
    Dernier message: 07/10/2014, 10h28
  2. Réponses: 1
    Dernier message: 18/09/2011, 01h55
  3. Réponses: 4
    Dernier message: 04/07/2008, 10h34
  4. Réponses: 1
    Dernier message: 22/06/2008, 22h47
  5. Afficher une image JPG qui se trouve dans une bdd
    Par Harry dans le forum Bases de données
    Réponses: 6
    Dernier message: 27/02/2004, 10h51

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