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

DB2 Discussion :

Passage de parametres avec caracteres spéciaux


Sujet :

DB2

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de keub51
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    349
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 349
    Par défaut Passage de parametres avec caracteres spéciaux
    Bonjour,

    Je souhaite éxécuter une Procédure Stockée qui me compte des maisl dans une table selon certains critères. Parmi ces critères on trouve un libellé sous forme de String. L'utilisateur peut en selectionner plusieurs ce qui m'oblige à utiliser IN.

    Voici une partie de ma requête :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
            SELECT 
              COUNT(*)
            FROM
              DO_EMLWEB a,
              DO_RFL b,
              DO_NWL c,
              DO_EMLWEBISCNWL d
            WHERE
              a.CODENS = codeEnseigne AND
              --Centres interets
              a.EMLCPTWEB = d.EMLCPTWEB AND
              d.IDNWL = c.IDFNWL AND
              c.RFLLIBNWL = b.IDFRFL AND
              b.VALRFL IN(PARAMETRE)
    Mon idée c'est de récuperer les libellé et de les concatener les uns a la suite des autres comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
                String chaineCI="";                                    
                 for(int i = 0;i<this.rchCI.length;i++)
                    {
                        chaineCI=chaineCI+"'"+rchCI[i]+"'";
                    }
    Ainsi chaineCI contiendra tous mes libellé et je pourrais ainsi les passé en parametre dans ma requete.

    Question : est ce que mon script plantera si l'un des libellés contient un " ' " ? Si oui avez vous une parade a cela ?

    Merci ...

  2. #2
    Membre éclairé Avatar de keub51
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    349
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 349
    Par défaut
    Comme un parfait noob je réponds à ma propre question mdr ( si tout le monde été comme ca il n'y aurait plus de forum lol )

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Il suffit de doubler les " ' " comme ceci :
     
                    for(int i = 0;i<this.rchCI.length;i++)
                        {
                        if(rchCI[i].indexOf("'")!=-1)
                            rchCI[i]=rchCI[i].replaceAll("'","''");                        
                        chaineCI=chaineCI+"'"+rchCI[i]+"'";
                        if(i!=this.rchCI.length-1)
                            chaineCI=chaineCI+",";
                        }
    voili voilou

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

Discussions similaires

  1. Passage de parametre avec <f:param>
    Par faico dans le forum JSF
    Réponses: 2
    Dernier message: 06/04/2007, 11h05
  2. pb passage de parametre avec le displaytag
    Par crocodingo dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 02/04/2007, 17h52
  3. Passage de parametre avec like
    Par Vinijano dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 23/01/2007, 12h53
  4. [XSL~FO] passage de parametre avec XSL/FO
    Par nosfer_13 dans le forum XSL/XSLT/XPATH
    Réponses: 4
    Dernier message: 12/07/2006, 10h23
  5. Valeur de parametre avec caractere "+"
    Par Nathan dans le forum Langage
    Réponses: 4
    Dernier message: 06/04/2006, 10h04

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