Dénormaliser plusieurs colonnes - Cloud - 8.0

Traitement (Processing) (Intégration)

Version
Cloud
8.0
Language
Français
Product
Talend Big Data
Talend Big Data Platform
Talend Data Fabric
Talend Data Integration
Talend Data Management Platform
Talend Data Services Platform
Talend ESB
Talend MDM Platform
Talend Open Studio for Big Data
Talend Open Studio for Data Integration
Talend Open Studio for ESB
Talend Real-Time Big Data Platform
Module
Studio Talend
Content
Création et développement > Systèmes tiers > Composants Processing (Intégration)
Gouvernance de données > Systèmes tiers > Composants Processing (Intégration)
Qualité et préparation de données > Systèmes tiers > Composants Processing (Intégration)

Procédure

  1. Cliquez et déposez les composants suivants : tFileInputDelimited, tDenormalize, tLogRow de la Palette vers l'espace de modélisation graphique.
  2. Connectez tous les composants à l'aide d'une connexion Row > main.
  3. Dans l'onglet Basic settings du composant tFileInputDelimited, renseignez le chemin d'accès au fichier à dénormaliser.
  4. Renseignez les autres champs, dont les champs Row Separator, Field separators et Header contenant respectivement les séparateurs de lignes et de champs et le nombre de lignes d'en-tête.
  5. Le schéma du fichier est composé de quatre colonnes : Name, FirstName, HomeCity, WorkCity.
    Name;FirstName;HomeCity;WorkCity
    Pitt;Brad;Berverly Hills;Los Angeles
    Pitt;Brad;Paris;London
    Joli;Angelina;Berlin;Berlin
    Joli;Angelina;Berlin;Los Angeles
    Joli;Angelina;Los Angeles;Los Angeles
    Willis;Bruce;Paris;Los Angeles
    Willis;Bruce;Paris;Madrid
    Willis;Bruce;Madrid;Paris
    Willis;Bruce;Roma;Dublin
    Moore;Demi;New York;Paris
    Moore;Demi;Rio de Janeiro;Los Angeles
  6. Dans l'onglet Basic settings du composant tDenormalize, sélectionnez les colonnes contenant les répétitions.
    Elles correspondent aux colonnes apparaissant plusieurs fois dans le document. Dans cet exemple, FirstName, HomeCity et WorkCity sont les colonnes à partir desquelles la dénormalisation est effectuée.
  7. Cliquez sur pour ajouter des lignes et définir les colonnes à dénormaliser.
  8. Dans la colonne Delimiter, paramétrez les séparateurs en les saisissant entre guillemets doubles, afin de séparer les valeurs concaténées.
  9. Sauvegardez votre Job et appuyez sur F6 pour l'exécuter.
    Les valeurs dénormalisées sont concaténées à l'aide d'un point-virgule.
    |=-----+--------------------------+-------------------------+------------------------------=|
    |Name  |FirstName                 |HomeCity                 |WorkCity                       |
    |=-----+--------------------------+-------------------------+------------------------------=|
    |Joli  |Angelina;Angelina;Angelina|Berlin;Berlin;Los Angeles|Berlin;Los Angeles;Los Angeles |
    |Moore |Demi;Demi                 |New York;Rio de Janeiro  |Paris;Los Angeles              |
    |Willis|Bruce;Bruce;Bruce;Bruce   |Paris;Paris;Madrid;Roma  |Los Angeles;Madrid;Paris;Dublin|
    |Pitt  |Brad;Brad                 |Berverly Hills;Paris     |Los Angeles;London             |
    '------+--------------------------+-------------------------+-------------------------------'
  10. Pour supprimer les occurrences en doublon, ouvrez la vue Basic settings du tDenormalize.
  11. Cochez la case Merge same value.
  12. Sauvegardez votre Job et appuyez sur F6 pour l'exécuter.

Résultats

Les occurrences en doublon sont fusionnées.
|=-----+---------+-----------------------+------------------------------=|
|Name  |FirstName|HomeCity               |WorkCity                       |
|=-----+---------+-----------------------+------------------------------=|
|Joli  |Angelina |Berlin;Los Angeles     |Berlin;Los Angeles             |
|Moore |Demi     |New York;Rio de Janeiro|Paris;Los Angeles              |
|Willis|Bruce    |Paris;Madrid;Roma      |Los Angeles;Madrid;Paris;Dublin|
|Pitt  |Brad     |Berverly Hills;Paris   |Los Angeles;London             |
'------+---------+-----------------------+-------------------------------'