Configurer le Job parent - 7.3

Exemples de Jobs d'intégration de données

Version
7.3
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 Real-Time Big Data Platform
Module
Studio Talend
Content
Création et développement > Création de Jobs
Last publication date
2024-02-13

Procédure

  1. Dans la vue Contexts :
    1. Ajoutez les trois variables suivantes :
      • filename, de type String
      • tablename, de type String
      • directory, de type Directory
    2. Spécifiez le répertoire en cliquant dans le champ Value de la variable directory. Cliquez sur le bouton qui apparaît et naviguez jusqu'au répertoire contenant les fichiers sources.
  2. Dans la vue Basic settings du composant tFileList, renseignez le champ Directory avec context.directory.
    Conseil : Cliquez dans le champ et appuyez sur Ctrl+Maj pour accéder à une liste de variables disponibles.
  3. Double-cliquez sur le composant tIterateToFlow pour ouvrir sa vue Basic settings et configurez le composant comme suit :
    1. Ajoutez une colonne nommée filename (de type String) dans l'éditeur de schéma.
    2. Renseignez le champ Value de la table Mapping avec la variable globale CURRENT_FILE générée par le composant tFileList, au format ((String)globalMap.get("tFileList_1_CURRENT_FILE")).
  4. Double-cliquez sur le composant tFixedFlowInput pour ouvrir sa vue Basic settings et configurez le composant :
    1. Ajoutez deux colonnes dans le schéma : file_name (de type String) et table_name (de type String).
    2. Sélectionnez l'option Use Inline Table et définissez les mappings fichier à table suivants dans la table :
      file_name table_name
      "customer_details.csv" "customer"
      "delivery_details.csv" "delivery"
      "employee_details.csv" : "employee"
  5. Double-cliquez sur le composant tMap pour ouvrir son éditeur de mapping, puis :
    1. Glissez la colonne filename de la table row1 (qui vient du composant tIterateToFlow) et déposez-la dans la colonne file_name de la table row2 (qui vient du composant tFixedFlowInput), pour joindre les deux tables pour le Lookup du nom du fichier.
    2. Cliquez sur le bouton à molette pour afficher les propriétés de jointure et définissez :
      • le Match Model sur Unique match
      • le Join Model sur Inner Join
    3. Dans l'éditeur de schéma, ajoutez deux colonnes à la table out : tablename (de type String) et filename (de type String).
    4. Glissez la colonne filename de la table row1 et déposez-la dans la colonne filename de la table out.
    5. Glissez la colonne table_name de la table row2 et déposez-la dans la colonne filename de la table out.
    6. Cliquez sur OK pour valider vos paramètres et l'éditeur de mapping.
  6. Double-cliquez sur le composant tJavaRow, puis saisissez le code suivant dans le champ Code.
    context.tablename = out.tablename;
    context.filename = out.filename;
  7. Dans la vue Basic settings du composant tRunJob :
    1. Cliquez sur le bouton [...] à côté du champ Job et sélectionnez le Job enfant que vous souhaitez appeler depuis la boîte de dialogue Repository Content, LoadDynamicSchemaChild dans cet exemple.
    2. Cochez l'option Transmit whole context pour transmettre les variables de contexte au Job enfant.
  8. Appuyez sur les touches Ctrl+S pour enregistrer le Job.