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

Servlets/JSP Java Discussion :

[JSP][SQL]Probleme de guillemets avec SQL


Sujet :

Servlets/JSP Java

  1. #1
    Membre émérite Avatar de Drizzt [Drone38]
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2004
    Messages
    1 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur de projet

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 001
    Points : 2 453
    Points
    2 453
    Par défaut [JSP][SQL]Probleme de guillemets avec SQL
    Bonjour, j'ai un petit probleme de guillemets.

    Voila ma requete SQL:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <sql:query var="tmp">
    	SELECT iID,szTitle  
    	FROM project
    	WHERE	iID IN ?
    	<sql:param value="${ring}" />
    </sql:query>

    le ${ring} est une chaine de caractere recuperee lors d'une autre requete. Si je l'affiche pas de probleme (ex de resultat: (95,45) )

    Par contre dans cette requete la, il ne veut pas.
    J'ai teste en entrant une valeur à la main cela fonctionne tres bien.
    Apparement il semblerait que des guillemets soient ajoutés automatiquement autour de ma string lors du passage en parametre, du coup sql ne comprends plus. (J'ai teste en mettant des guillemets ' à la main et j'obtient le meme probleme).

    J'ai aussi essaye de retirer les ( ) de ma string et de les mettre dans la requete directement mais la, seul la premiere valeure presente dans les parenthese est reportée.

    Quelqu'un aurait une idée ?

    Merci
    Je ne réponds pas aux questions techniques par MP, le forum est là pour cela.

    La crypto c'est comme les flambys, une fois que tu as trouvé la languette tu as juste à tirer pour tout faire tomber.

    (\ _ /)
    (='.'=)
    Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant

  2. #2
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    C'est normal car <sql:param/> se base sur le type réel de value pour l'associer au type SQL correspondant :
    http://adiguba.developpez.com/tutori...l/#L-sql:param

    Comme ring est une string, il l'associe au type VARCHAR de SQL et l'entoure donc de quote...
    Ce qui te pose problème puique ring ne correspond pas à un type SQL mais à une portion de la requête.

    La meilleur solution serait de mettre directement ton ${ring} dans la requête, par exemple (avec les EL de JSP 2.0) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <sql:query var="tmp">
       SELECT iID,szTitle 
       FROM project
       WHERE   iID IN ${ring}
    </sql:query>
    Ou bien avec les JSP 1.1/1.2 et la JSTL 1.0 :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <sql:query var="tmp">
       SELECT iID,szTitle 
       FROM project
       WHERE   iID IN <c:out value="${ring}"/>
    </sql:query>
    a++

  3. #3
    Membre émérite Avatar de Drizzt [Drone38]
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2004
    Messages
    1 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur de projet

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 001
    Points : 2 453
    Points
    2 453
    Par défaut
    Merci beaucoup ça marche très bien ! Et en plus avec les explications pour que j'en comprenne la raison.


    Encore merci.
    Je ne réponds pas aux questions techniques par MP, le forum est là pour cela.

    La crypto c'est comme les flambys, une fois que tu as trouvé la languette tu as juste à tirer pour tout faire tomber.

    (\ _ /)
    (='.'=)
    Voici Lapinou. Aidez le à conquérir le monde
    (")-(") en le reproduisant

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

Discussions similaires

  1. [SQL] - Probleme de requete avec SUM
    Par toxycyty dans le forum Langage SQL
    Réponses: 9
    Dernier message: 05/02/2009, 15h33
  2. Probleme d update avec sql express
    Par libremax dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 27/03/2008, 16h16
  3. [SQL plus][pl/sql] Probleme de spool avec PL/SQL
    Par ingamo dans le forum PL/SQL
    Réponses: 2
    Dernier message: 08/02/2007, 09h38
  4. probleme de taille avec sql server 2000
    Par sergio122 dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 13/02/2006, 09h57
  5. Réponses: 7
    Dernier message: 18/07/2005, 13h42

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