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

SQL Oracle Discussion :

contains() et caractères spéciaux


Sujet :

SQL Oracle

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 23
    Points : 16
    Points
    16
    Par défaut contains() et caractères spéciaux
    Salut tous!

    N'étant sûrement pas le premier à devoir faire ce genre de chose, je me disais qu'il doit exister une fonction toute bête dans Oracle pour mettre un \ devant les caractères spéciaux (- _ et autres). Mais rien trouvé de très convaincant...

    Est-ce que quelqu'un sait comment on peut faire un replace avec une sorte de matcher ? Par exemple on donne une liste de caractères, et la fonction ajoute un backslash devant tous les caractères correspondant dans le texte.

    Merci d'avance pour votre aide!

  2. #2
    Membre averti Avatar de dariyoosh
    Profil pro
    Inscrit en
    Avril 2009
    Messages
    236
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2009
    Messages : 236
    Points : 334
    Points
    334
    Par défaut
    Bonjour,


    Avez-vous essayé la fonction TRANSLATE? ça ne sera pas 100% automatique car il faut définir la liste des caractères à remplacer avec ce qu'il faut mettre comme remplaçant.

    http://psoug.org/reference/translate_replace.html

    Cordialement,
    Dariyoosh

  3. #3
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 23
    Points : 16
    Points
    16
    Par défaut
    Bonjour Dariyoosh,

    J'ai essayé avec TRANSLATE oui, mais le problème c'est que cette fonction ne permet que de remplacer un caractère pour un caractère. Ce qu'il me faudrait, c'est remplacer '_' par '\_'.

    Merci pour votre réponse !

  4. #4
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SQL> Select regexp_replace('Ce qu''il me faudrait, c''est remplacer ''_'' par %','([_%])','\\\1') from dual;
     
    REGEXP_REPLACE('CEQU''ILMEFAUD
    -------------------------------------------------
    Ce qu'il me faudrait, c'est remplacer '\_' par \%
    Mais replace(replace(replace... marche aussi.

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    23
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Janvier 2008
    Messages : 23
    Points : 16
    Points
    16
    Par défaut
    Citation Envoyé par mnitu Voir le message
    Mais replace(replace(replace... marche aussi.
    Oui en effet, j'ai fait de cette manière finalement. Si c'est possible de le faire avec un seul appel de fonction ça évite d'avoir des requêtes longues comme le bras, mais plusieurs REPLACE ça fonctionne. Merci !

Discussions similaires

  1. caractères spéciaux
    Par mat10000 dans le forum Flash
    Réponses: 16
    Dernier message: 23/10/2003, 13h22
  2. Où trouver la liste des caractères spéciaux?
    Par gamez dans le forum Langage
    Réponses: 3
    Dernier message: 19/08/2003, 17h54
  3. Transformation XSL et caractères spéciaux
    Par Sylvain Leray dans le forum XMLRAD
    Réponses: 4
    Dernier message: 28/04/2003, 10h38
  4. [Sybase] filtre sur caractères spéciaux
    Par montelieri dans le forum Sybase
    Réponses: 4
    Dernier message: 07/04/2003, 16h49
  5. Traiter les caractères spéciaux
    Par ricola dans le forum Langage
    Réponses: 2
    Dernier message: 20/02/2003, 09h23

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