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 :

Jdbc & mysql. Prepared statement


Sujet :

JDBC Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mai 2012
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2012
    Messages : 10
    Par défaut Jdbc & mysql. Prepared statement
    Bonjour à tous,

    Voila un code test on ne peut plus minimal:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    java.sql.Connection conn = DriverManager.getConnection(url,username,password);
     
                PreparedStatement pstmt = conn.prepareStatement("SELECT * FROM ?;");
    			pstmt.setString(1, "mytable");
     
    			ResultSet rs = pstmt.executeQuery();
    Voila l'erreur retourné:

    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 ''mytable'' at line 1

    Il me semble que je respecte la syntaxe... et je ne comprends pas du tout cette erreur.

    Merci d'avance pour tout renseignement !
    Ss.

  2. #2
    Membre Expert
    Profil pro
    Inscrit en
    Août 2006
    Messages
    3 276
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 3 276
    Par défaut
    Je ne suis pas certain que tu puisses paramétrer le nom d'une table, voilà à mon avis la source de l'erreur.

  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
    Par défaut
    Vire aussi le ";" dans la requête.

  4. #4
    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
    Je ne suis pas certain que tu puisses paramétrer le nom d'une table
    En effet.
    Le système du "?" du preparedStatement est pensé pour résoudre les problèmes de guillemets et d'apostrophes dans les données String, le parse des dates, des nombres etc...
    enfin tous les trucs casse-pied qui dépendent du SGBD et de la "locale" et sont saisis de façon aléatoire par l'utilisateur

    Par contre, la liste des tables d'un SGBD est fixe et on ne met jamais de guillemets dans le nom d'une table donc on peut écrire sans problème :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    "SELECT * FROM " + maTable
    sans passer par un 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/

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

Discussions similaires

  1. Prepare Statement jdbc
    Par punisher999 dans le forum JDBC
    Réponses: 18
    Dernier message: 19/09/2008, 16h41
  2. Prepared statement en C pour MySQL
    Par jenova dans le forum Réseau
    Réponses: 6
    Dernier message: 05/05/2008, 17h48
  3. Réponses: 2
    Dernier message: 05/07/2004, 17h50
  4. [JDBC]java - mysql : Pb de driver
    Par xiao-long974 dans le forum JDBC
    Réponses: 2
    Dernier message: 03/06/2004, 09h19

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