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

Développement de jobs Discussion :

Plusieurs jointures avec une même table


Sujet :

Développement de jobs

  1. #1
    Membre éclairé Avatar de bstevy
    Homme Profil pro
    Solutions Architect
    Inscrit en
    Mai 2009
    Messages
    552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Japon

    Informations professionnelles :
    Activité : Solutions Architect
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 552
    Points : 870
    Points
    870
    Par défaut Plusieurs jointures avec une même table
    Bonjour,

    J'ai un petit souci avec Talend, j'ai pas tellement l'habitude, je suis un utilisateur de DataStage lol !!

    Bref, voici mon cas :

    Je dispose de deux tables :

    Table 1
    • Code1
    • Code2
    • Code3


    Table 2
    • Code
    • libélé


    Vous l'avez peut etre compris a ce moment la, je veux faire la table suivante :

    Table résultat
    • Code1
    • lib1
    • code2
    • lib2
    • code3
    • lib3


    En effectuant trois jointure d'affilée.

    Ce que j'aurais voulu, c'est savoir comment je fais ca sous Talend, car lorsque j'essaye de tirer 3 sortie d'un map vers un autre, ca veut pas me le prendre.
    Je peux bien sur appeler trois fois ma table, mais c'est pas la solution non plus, car la, j'ai simplifié le schema, et en fait, c pas veritablement trois tables, mais y'a de lourdes transfo avant, donc oubliez.

    Voila, donc si vous pouvez me conseiller sur les elements a utiliser, ca serait cool !!


    Merci d'avance

  2. #2
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 247
    Points : 277
    Points
    277
    Par défaut
    Tu peux passer ton lien principal d'un tMap vers un autre tMap.
    Par contre, pour les autres, tu vas devoir passer par des fichiers temporaires, et ils seront définis en lookup.

  3. #3
    Membre éclairé Avatar de bstevy
    Homme Profil pro
    Solutions Architect
    Inscrit en
    Mai 2009
    Messages
    552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Japon

    Informations professionnelles :
    Activité : Solutions Architect
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 552
    Points : 870
    Points
    870
    Par défaut
    C bien ce que j'ai pas envi de faire lol !!!
    c'est des grosses volumetrie, j'ai pas specialement envi de les stocker et de les rapeler à chaque fois... au niveau des perf, c pas genial !

  4. #4
    Membre expérimenté Avatar de Benoit_Durand
    Profil pro
    Consultant en Business Intelligence Freelance
    Inscrit en
    Mars 2005
    Messages
    861
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence Freelance

    Informations forums :
    Inscription : Mars 2005
    Messages : 861
    Points : 1 308
    Points
    1 308
    Par défaut
    Le plus rapide c'est un seul select avec les jointures dedans. S'il y a des indexs il n'y a pas plus rapide avec Talend.
    Pensez à la fonction Recherche

  5. #5
    Membre éclairé Avatar de bstevy
    Homme Profil pro
    Solutions Architect
    Inscrit en
    Mai 2009
    Messages
    552
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : Japon

    Informations professionnelles :
    Activité : Solutions Architect
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2009
    Messages : 552
    Points : 870
    Points
    870
    Par défaut
    non, mais ca non plus ca marche pas... on a essayé de créer une vue, et le select est trop gourmand ! donc, la je recré tout en talend, pour economiser de la BDD !

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    247
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 247
    Points : 277
    Points
    277
    Par défaut
    Comme l'a dit Hebus_Beer, rien n'est plus performant que d'exploiter le moteur de la BDD.

    Donc, si tu ne peux pas faire tout dans une requête SQL, tu n'as malheureusement pas le choix que de passer par des lookup...

    A priori, je dirais que le plus simple c'est que tu fasses un extract de ta table 2 dans un fichier plat, pour limiter les accès BDD lors du traitement.

    Et ensuite, tu pars de ta table 1 et tu fais tes lookup avec ton fichier plat.

    Pour ce qui est des "problèmes" de schéma des tables et fichiers, tu peux utiliser les metadata pour gagner du temps, et ne définir ton format qu'une seule fois.

  7. #7
    Membre expérimenté Avatar de Benoit_Durand
    Profil pro
    Consultant en Business Intelligence Freelance
    Inscrit en
    Mars 2005
    Messages
    861
    Détails du profil
    Informations personnelles :
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Consultant en Business Intelligence Freelance

    Informations forums :
    Inscription : Mars 2005
    Messages : 861
    Points : 1 308
    Points
    1 308
    Par défaut
    Pour info il y a combien de lignes dans Table1 et Table2 ?
    Une procédure stockée serait plus performante mais si le sgbd n'arrive pas à faire les jointures ...
    Le plan d'exécution du select ne semble pas améliorable ?
    Pensez à la fonction Recherche

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

Discussions similaires

  1. [AC-2003] Plusieurs tables en relation avec une même table
    Par Invité dans le forum Modélisation
    Réponses: 9
    Dernier message: 20/04/2012, 11h37
  2. [MySQL] SELECT * avec jointure sur une même table
    Par Oprichnik dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 09/03/2011, 13h17
  3. [MySQL] Plusieurs jointures sur une même table
    Par stephyyr dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/06/2006, 14h24
  4. [Requête] plusieurs champs dans une même table ayants la même source
    Par Christophe93250 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 25/04/2006, 16h18
  5. jointure sur une même table
    Par guillaumeVb6 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 06/09/2004, 15h08

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