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

Langage Java Discussion :

Problème de syntaxe


Sujet :

Langage Java

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 116
    Points : 66
    Points
    66
    Par défaut Problème de syntaxe
    Bonjour,

    J'ai un problème de syntaxe.
    J'ai une requete sql de la forme dans une classe:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    public string req="select * from table where nom=' +this.getNom()+' AND METIER=1"
    je veux appeler cette variable dans une autre classe :
    comment puis-je faire en sorte que le getnom soit interprété et que sa m'affiche pas tous simplement getnom je pense que c'est une histoire de syntaxe et de ' ou ".

    Merci de votre aide.

  2. #2
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    Je te recommande très fortement d'utiliser des instructions paramétrées (aka PreparedStatement) qui sont prévus à cet effet.

    Ils sont prévus pour éviter tout problème des gestions des quotes & cie.
    Hey, this is mine. That's mine. All this is mine. I'm claiming all this as mine. Except that bit. I don't want that bit. But all the rest of this is mine. Hey, this has been a really good day. I've eaten five times, I've slept six times, and I've made a lot of things mine. Tomorrow, I'm gonna see if I can't have sex with something.

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 116
    Points : 66
    Points
    66
    Par défaut
    Merci pour ta réponse j'essaye de le faire comme sa, mais est-ce qu'il existe pas une solution avec les quotes et compagnies que je pourrais me servir un jour au cas ou pour un problème similaire en dehors des requêtes.
    Encore merci de ta réponse

  4. #4
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    Pour faire simple. Cette méthode n'a absolument aucun intérêt vu que tous les drivers JDBC fournissent des PreparedStatement.

    A noter qu'ici ton erreur vient du fait qu'une instruction java contenue dans une chaine ne sera absolument pas exécutée, vue que le contenu des chaines n'est pas considéré par java comme étant du code.

    Tu aurais du faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    String query = "select * from table where nom='"+this.getNom()+"' AND METIER=1";
    Ou mieux encore

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    String query = new StringBuilder().append("select * from table where nom='").append(this.getNom()).append("' AND METIER=1").toString();
    L'utilisation d'un StringBuilder étant à préférer à l'opérateur + pour réaliser des concaténations de chaines pour des raisons de vitesse et d'occupation mémoire.
    Hey, this is mine. That's mine. All this is mine. I'm claiming all this as mine. Except that bit. I don't want that bit. But all the rest of this is mine. Hey, this has been a really good day. I've eaten five times, I've slept six times, and I've made a lot of things mine. Tomorrow, I'm gonna see if I can't have sex with something.

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 116
    Points : 66
    Points
    66
    Par défaut
    Merci,

    Tu dit que le contenu des chaines n'est pas considéré par java comme étant du code.
    N'y a t-il aucun moyen pour dire à java qu'une partie de la chaine doit l'être?
    Car mon GetNom et dans une autre classe, donc si je le déclare sa me provoque une erreur normale.
    Donc je voudrais que le String soit que un string avec une partie du code interprétable quand j'appelle cette constante. Si sa n'existe pas c'est pas grave c'est que pour ma culture personnel ^^

    Merci d'avoir pris le temps de me répondre

  6. #6
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    Non, ce n'est pas possible. Ca ne fait pas partie de la spécification java et n'en fera jamais partie. A toi d'architecturer correctement ton application pour que tu aies à disposition le nom quand tu crées la requête...

    Je te conseille la lecture du tutoriel suivant afin d'avoir une idée d'une façon propre d'organiser ses couches d'accès aux données en java.

    http://cyrille-herby.developpez.com/...c-pattern-dao/
    Hey, this is mine. That's mine. All this is mine. I'm claiming all this as mine. Except that bit. I don't want that bit. But all the rest of this is mine. Hey, this has been a really good day. I've eaten five times, I've slept six times, and I've made a lot of things mine. Tomorrow, I'm gonna see if I can't have sex with something.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2008
    Messages
    116
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2008
    Messages : 116
    Points : 66
    Points
    66
    Par défaut
    Merci pour cette remarque, la doc et de m'avoir répondu.

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

Discussions similaires

  1. Problème de syntaxe - elements['x'].value
    Par Equus dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 22/02/2005, 11h22
  2. [Interbase] Problème de syntaxe SQL
    Par navis84 dans le forum InterBase
    Réponses: 4
    Dernier message: 22/12/2004, 17h07
  3. Problème de syntaxe
    Par Mister_FX dans le forum ASP
    Réponses: 5
    Dernier message: 30/06/2004, 10h01
  4. Problème de syntaxe ADO ...
    Par bendev dans le forum ASP
    Réponses: 2
    Dernier message: 15/04/2004, 14h38
  5. Réponses: 2
    Dernier message: 08/03/2004, 15h10

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