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 :

SQL Fonction TRANSLATE


Sujet :

SQL Oracle

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 277
    Par défaut SQL Fonction TRANSLATE
    Bonjour,

    J'ai cherché un peu partout sur internet et je ne trouve pas la réponse à ma question. Je recherche une explication claire (au moins pour moi) de la fonction TRANSLATE.
    Voici la requête que j'exécute :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select CHAMP,  TRANSLATE(CHAMP, '*', '0123456789'),  TRANSLATE(CHAMP, '*', ' 0123456789') from DWH.TABLE
    Je vous joins les résultats.

    J'avais cru comprendre que si, caractère par caractère, le caractère du 1er argument se trouve dans le 2e, alors on retourne le caractère du 3e argument à la position où on l'a trouvé dans le 2e argument.

    Mais dans ma requête, ça ne fonctionne pas. On n'obtient pas les mêmes résultats si le 3e argument commence par un espace.

    Mon but ultime est de chercher si le champ CHAMP ne contient que des chiffres : en faisant un RTRIM et en comparant la longueur à 0, ça semble fonctionner.

    Mais j'aimerais bien comprendre !! Sauriez-vous m'aider svp ?

    Par avance, merci.
    Fichiers attachés Fichiers attachés

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Mon but ultime est de chercher si le champ CHAMP ne contient que des chiffres : en faisant un RTRIM et en comparant la longueur à 0, ça semble fonctionner.
    Pour ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    LTRIM(champ, '0123456789') IS NULL -- n'a pas autre chose que des chiffres
    AND champ IS NOT NULL -- contient au moins un caractère

    Pour le TRANSLATE (p1, p2, p3) : Les 3 sont obligatoires.
    Remplace dans la chaine p1, le premier caractère de p2 par le premier caractère de p3, le second de p2 par le second de p3, etc..
    Si pour un xème caractère de p2, il n'y a pas de xème caractère dans p3, alors le xème caractère de p2 est supprimé dans p1 (remplacé par NULL)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select CHAMP,  TRANSLATE(CHAMP, '*', '0123456789') t1,  TRANSLATE(CHAMP, '*', ' 0123456789') t2 from DWH.TABLE
    t1 : Transforme tous tes '*' par '0'
    t2 : transforme toutes tes '*' par ' '

    Mais c'est mal formé, les caractères '123456789' de t1 sont inutiles et le caractères '0123456789' sont inutiles

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    p2 : '0123456789'
    p3 : 'abcdefghi' 
     
    0->a; 1->b, 2->c, 3->d, 4->e, 5->f, 6->g, 7->h, 8->i, 9->supprimé
    Le principal intérêt du translate est le multi replace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TRANSLATE(champ, '012', 'abc') = REPLACE(REPLACE(REPLACE(champ, '0', 'a'), '1','b'), '2','c')
    Et aussi de pouvoir enlever des caractères dans des chaines (p3 étant obligatoire, il faut forcément remplacer au moins un caractère que tu souhaites garder)
    Exemple enlever tous les chiffres d'une chaîne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TRANSLATE('jour : 25/09/2019', ' 0123456789', ' ')
    Et pour finir (astuce vu sur le forum) : Pour ne garder que les caractères souhaités (exemple que les chiffres) : On fait la liste de tous les caractères autres que ceux qu'on veut garder et ce sera une liste des caractères à supprimer.
    double translate
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    TRANSLATE('jour : 25/09/2019', '0' || TRANSLATE('jour : 25/09/2019', '0123456789', '0'),'0') 
     
    TRANSLATE('jour : 25/09/2019', '0123456789', '0') : On remplace tous les 0 par 0 et on supprime tous les 1-9
    La chaine sera 'jour : /0/0'
     
    Ensuite on retranslate sur le résultat
    TRANSLATE('jour : 25/09/2019', '0jour : /0/0','0') : On remplace tous les 0 par 0, et on supprime les autres caractères (j, o, u, r, <espace>, :, /) .
     
    Résultat 25092019

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 277
    Par défaut
    Bonjour McM,

    Je vous remercie avec beaucoup de retard pour votre réponse très complète. Cependant, la base de données cible est DB2 et les commandes que vous l'indiquez ne retournent pas les mêmes résultats que ceux que vous précisez.
    Ce sujet avait été créé à l'origine dans un forum SQL général mais un administrateur l'avait déplacé ici car ce forum était susceptible d'apporter plus de réponses.

    Cependant, ma mission est aujourd'hui terminée et je n'ai plus besoin d'avoir la réponse. Quoiqu'il en soit vous m'avez permis de comprendre le fonctionnement global de cette fonction.

    Merci beaucoup

    PS : je ne trouve pas comment préciser que ce post est en délestage

  4. #4
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Pas de soucis.
    Par contre, pas besoin de le mettre en Délestage je pense, laisse moi au moins le plaisir d'avoir l'explication complète qui pourra servir pour quelqu'un d'autre.

    Tu dois avoir un bouton quelque part (je sais plus s'il est en haut ou en bas)

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Avril 2003
    Messages
    277
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2003
    Messages : 277
    Par défaut
    On l'a taggé résolu à ma place mais je confirme que c'est bien le cas !
    L'explication est très claire et très complète.

    Merci McM

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

Discussions similaires

  1. [AccessXP][SQL]Fonction NZ() et concaténation
    Par steelidol dans le forum Access
    Réponses: 3
    Dernier message: 08/10/2005, 18h27
  2. Réponses: 4
    Dernier message: 18/08/2005, 16h11
  3. Réponses: 5
    Dernier message: 13/07/2005, 10h03
  4. [PL/SQL] fonction et alter session
    Par aline dans le forum Oracle
    Réponses: 10
    Dernier message: 26/01/2005, 15h23
  5. [PL/SQL] Fonction qui retourne plusieurs valeurs
    Par Loko dans le forum Oracle
    Réponses: 2
    Dernier message: 07/12/2004, 09h43

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