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

SSIS Discussion :

Différence entre l'opérateur de jointure et la requête SQL


Sujet :

SSIS

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    237
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2004
    Messages : 237
    Par défaut Différence entre l'opérateur de jointure et la requête SQL
    Bonjour,

    J'ai 2 tables SQL Server issues de différentes transformations SSIS que je souhaite joindre. La première a plus de 2.500.000 enregs et la deuxième 8000.
    Lorsque j'utilise l'opérateur de jointure SSIS j'obtiens 53000 enregs.
    Lorsque je fait une requête SQL (inner join) j'obtiens les 2.500.000 enregs de la première table ce qui est conforme à mes attentes.
    À votre avis, d'où vient la différence entre ces résultats? Y'a t'il un moyen de voir la requête générée par SSIS?

    Merci,
    Jean

  2. #2
    Membre expérimenté Avatar de arnaudvoisin
    Homme Profil pro
    Consultant BI chez WAISSO
    Inscrit en
    Janvier 2007
    Messages
    156
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Consultant BI chez WAISSO

    Informations forums :
    Inscription : Janvier 2007
    Messages : 156
    Par défaut
    Bonjour jpclabaux,

    Tu parles d'une opération de rapprochement via l'opérateur SSIS Merge Join.
    Ce composant nécessite que les 2 flux upstream soient triés. Il est possible que via les propriétés amont tu aies défini les colonnes de jointure du merge en tant que colonne trié ce qui t'a permis d'utiliser le composant alors qu'en réalité les données ne sont pas triées.
    Au final ton opération de jointure ne donne pas le résultat attendu.

    Je commencerais à ta place par vérifier mes tris.

    Arnaud VOISIN
    Consultant BI chez WAISSO | MCITP - SQL SERVER 2008 BI
    http://arnaudvoisin.blogspot.fr/
    http://www.waisso.com/

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    237
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2004
    Messages : 237
    Par défaut
    Bonjour Arnaud,

    Merci de t'intéresser à ma question!
    J'utilise effectivement le Merge Join. Pour m'assurer que les données soient triées de la même manière j'utilise pour chaque table l'opérateur Sort.
    Sais-tu si on peut accéder au code sql généré par ssis?

    Jean

  4. #4
    Membre expérimenté Avatar de arnaudvoisin
    Homme Profil pro
    Consultant BI chez WAISSO
    Inscrit en
    Janvier 2007
    Messages
    156
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Consultant BI chez WAISSO

    Informations forums :
    Inscription : Janvier 2007
    Messages : 156
    Par défaut
    Je pense que pour identifier ton problème de jointure dans ton package, tu devrais poser des dataviewers sur les flux amonts de ton Merge Join afin de comprendre.

    SSIS n'est pas une générateur de code SQL, mais un ETL. Les données sont montées en mémoire dans ce qu'on appelle un pipeline. Les données sont transformées dans cette espace. Je ne pense pas que tu puisses transposer le fonctionnement de ton DataFlow sur le plan d'exécution d'une requête.

    Maintenant si tu veux visualiser les interactions de ton package sur le moteur, tu peux utiliser le Profiler.

    Arnaud VOISIN
    Consultant BI chez WAISSO | MCITP - SQL SERVER 2008 BI
    http://arnaudvoisin.blogspot.fr/
    http://www.waisso.com/

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Octobre 2004
    Messages
    237
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2004
    Messages : 237
    Par défaut
    Je vais essayer ça et je te reviens.

  6. #6
    Membre chevronné
    Homme Profil pro
    Consultant en Business Intelligence
    Inscrit en
    Novembre 2010
    Messages
    304
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Consultant en Business Intelligence
    Secteur : Conseil

    Informations forums :
    Inscription : Novembre 2010
    Messages : 304
    Par défaut
    Ton merge join est bien configuré en inner join ?

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

Discussions similaires

  1. Différences entre les algorithmes de jointure
    Par kochfet dans le forum Optimisations
    Réponses: 0
    Dernier message: 11/06/2013, 10h18
  2. Différences entre les types de jointures
    Par Age_of_Aquarius dans le forum Langage SQL
    Réponses: 7
    Dernier message: 29/04/2013, 03h55
  3. Réponses: 2
    Dernier message: 18/09/2012, 14h14
  4. [AC-2010] Calculer la différence entre deux dates, en jour, dans une requête
    Par Just-Soft dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 31/10/2010, 02h19
  5. Plusieurs jointures dans une requête sql
    Par Pero dans le forum Langage SQL
    Réponses: 3
    Dernier message: 21/09/2005, 20h59

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