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

Oracle Discussion :

Fonction qui renvoie les premières lettres d'une suite de mots


Sujet :

Oracle

  1. #1
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut Fonction qui renvoie les premières lettres d'une suite de mots
    Bonjour,

    je cherche une fonction qui permet de renvoyer les premières lettres d'une suite de mots.

    Exemple : Jean Pierre -> jp

    Est-ce que cela existe ?

    Merci.

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 394
    Points
    18 394
    Par défaut
    En jouant avec lower, initcap et translate, ça doit fonctionner :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select translate(initcap(lower(nom)), 'A abcdefghijklmnopqrstuvwxyz', 'A') as res
      from (select 'Jean pierre' as nom from dual);
     
    RES
    ---
    JP

  3. #3
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    Bonjour,

    Effectivement cela marche bien.
    Je n'aurai jamais pensé à faire cela comme ca.

    Merci

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 394
    Points
    18 394
    Par défaut
    J'avais commencé à regarder des expressions régulières, mais ce n'est pas mon point fort alors j'ai détourné ainsi.
    Il y a peut-être plus simple avec les REGEXP.

  5. #5
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    moi cela me convient.

    Merci à toi

  6. #6
    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
    Citation Envoyé par Waldar Voir le message
    J'avais commencé à regarder des expressions régulières, mais ce n'est pas mon point fort alors j'ai détourné ainsi.
    Il y a peut-être plus simple avec les REGEXP.
    Peut être quelque chose comme ça.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SQL> SELECT regexp_replace('Jean Pierre','(^|\s)(\w)(\w)+','\2') AS nom FROM dual;
     
    NOM
    ---
    JP

  7. #7
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Attention, initcap considère qu'un trait d'union sépare 2 mots.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT INITCAP(LOWER('jean-pierre pernot'))
    FROM dual
     
    Jean-Pierre Pernot

  8. #8
    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
    Mais on peut jouer avec les expressions régulières

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SQL> SELECT regexp_replace('Jean-Pierre Pernot','(^|\s)(\S)(\S)+','\2') AS nom FROM dual;
     
    NOM
    ---
    JP

  9. #9
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    bonjour,

    j'ai essayé toutes vos solutions avec les expressions régulières.
    J'avoue ne pas tout comprendre.

    Mais est il possible de faire en sorte avec une expression régulière que :
    jean-Pierre ou Jean Pierre ou Jean Pierre renvoient JP ?

    J'avais contourné le soucis comme cela :

    SELECT translate(initcap(lower(nom)), 'A abcdefghijklmnopqrstuvwxyz-', 'A') into initiale FROM (SELECT chaine AS nom FROM dual);
    en ajoutant le - dans la liste
    Merci à vous

  10. #10
    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
    Non, il faut un upper
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    SQL> With data As (
      2  Select 'jean-Pierre' as nom from dual union all
      3  Select 'Jean Pierre'  from dual union all
      4  Select 'Jean Pierr' from dual
      5  )
      6  Select Upper(regexp_replace(nom,'(^|\s|-)(\w)(\w)*','\2')) FROM data
      7  /
     
    UPPER(REGEXP_REPLACE(NOM,'(^|\
    --------------------------------------------------------------------------------
    JP
    JP
    JP
    Ca commence soit au début de la chaine soit avec un blanc soit avec un – constitué dans un group, suivi d'un caractère alphanumérique dans un group, suivi de zéro ou plusieurs caractères alphanumériques dans un troisième group. Le deuxième group c’est-à-dire le caractère qui suit le début du mot est utilisé à la place du mot.

  11. #11
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Avec initcap (méthode de Waldar simplifiée)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    WITH DATA AS (
    SELECT 'jean-Pierre' AS nom FROM dual UNION ALL
    SELECT 'Jean Pierre'  FROM dual UNION ALL
    SELECT 'Jean Pierr' FROM dual
    )
    SELECT nom, REPLACE(TRANSLATE(INITCAP(LOWER(nom)), LOWER(nom), LPAD(' ', LENGTH(nom))), ' ') cpde
    FROM DATA
     
    NOM		CPDE
    jean-Pierre	JP
    Jean Pierre	JP
    Jean Pierr	JP

  12. #12
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 394
    Points
    18 394
    Par défaut
    Excellente idée le translate de l'initcap sur le nom !

    Par contre je ne vois pas l'intérêt du lpad avec la longueur puisqu'au final ces espaces on va les sucrer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    WITH DATA AS
    (
    SELECT 'jean-Pierre' AS nom FROM dual UNION ALL
    SELECT 'Jean Pierre'        FROM dual UNION ALL
    SELECT 'Jean Pierr'         FROM dual
    )
    SELECT nom,
           REPLACE(TRANSLATE(INITCAP(LOWER(nom)), LOWER(nom), ' '), ' ') cpde
      FROM DATA;
     
    NOM		CPDE
    jean-Pierre	JP
    Jean Pierre	JP
    Jean Pierr	JP

  13. #13
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Bien vu !

    Erreur de débutant / fatigue de ma part (rayer la mention inutile)

  14. #14
    Membre éprouvé Avatar de shaun_the_sheep
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Octobre 2004
    Messages
    1 619
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : Enseignement

    Informations forums :
    Inscription : Octobre 2004
    Messages : 1 619
    Points : 996
    Points
    996
    Par défaut
    et bien merci à vous.
    Très intéressant.

    Même si je pense ne retenir que la dernière solution , les autres m'auront au moins permis d'enrichir mes connaissances en matière de sql.

  15. #15
    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
    Citation Envoyé par Waldar Voir le message
    Excellente idée le translate de l'initcap sur le nom !
    ...
    Tout à fait d'accord!

    Citation Envoyé par Waldar Voir le message
    Par contre je ne vois pas l'intérêt du lpad avec la longueur puisqu'au final ces espaces on va les sucrer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    WITH DATA AS
    (
    SELECT 'jean-Pierre' AS nom FROM dual UNION ALL
    SELECT 'Jean Pierre'        FROM dual UNION ALL
    SELECT 'Jean Pierr'         FROM dual
    )
    SELECT nom,
           REPLACE(TRANSLATE(INITCAP(LOWER(nom)), LOWER(nom), ' '), ' ') cpde
      FROM DATA;
     
    NOM		CPDE
    jean-Pierre	JP
    Jean Pierre	JP
    Jean Pierr	JP
    Mais, je pense que le Replace est lui aussi en trop.

  16. #16
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    Non, il faut le replace
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    WITH DATA AS
    (
    SELECT 'jjean-Pierre' AS nom FROM dual UNION ALL
    SELECT 'Jean PierreJ'        FROM dual UNION ALL
    SELECT 'Jean Pierr'         FROM dual
    )
    SELECT nom,
           '#'|| TRANSLATE(INITCAP(LOWER(nom)), LOWER(nom), ' ') || '#' cpde
      FROM DATA;
     
    NOM	CPDE
    jjean-Pierre	#J P#
    Jean PierreJ	#JP #
    Jean Pierr	#JP#

  17. #17
    McM
    McM est déconnecté
    Expert éminent

    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
    Points : 7 740
    Points
    7 740
    Billets dans le blog
    4
    Par défaut
    La seule façon de virer le replace est de ne pas générer d'espace, donc cette solution fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TRANSLATE(INITCAP(LOWER(nom)), 'X'||LOWER(nom), 'X')
    D'ailleurs, je pense que c'est plus optimisé.

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

Discussions similaires

  1. fonction qui retourne les première lettres de chaque mot en PHP
    Par simonlaurent5000 dans le forum Langage
    Réponses: 5
    Dernier message: 22/02/2012, 21h50
  2. Fonction qui renvoie la dernière valeur d'une plage
    Par brunoSCP dans le forum Excel
    Réponses: 5
    Dernier message: 12/02/2010, 18h53
  3. Fonction qui renvoie les coordonnée de la cellule
    Par osoursou dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 22/11/2009, 20h22
  4. fonction qui renvoie un un objet d'une autre classe
    Par miloon dans le forum Débuter
    Réponses: 3
    Dernier message: 16/02/2009, 21h45
  5. [RegEx] Modifier les premières lettre d'une clé
    Par superkikim dans le forum Langage
    Réponses: 1
    Dernier message: 04/03/2008, 05h12

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