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 SQL Server Discussion :

Procédure stockée jointure


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Développeur Web
    Inscrit en
    Janvier 2011
    Messages
    49
    Détails du profil
    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2011
    Messages : 49
    Par défaut Procédure stockée jointure
    Bonjour,
    j'ai une table qui contient les colonnes suivantes:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Table 1
    [Id] | [CatalogId] | [Date] | [Lang] | [Country]......
    et une autre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Table 2
    [CatalogId]|[Email]|[Colonne3]....[Colonne]
    Le but de ma requête est d'obtenir les 50 lignes les plus récentes de la table 1 mais qui a un email (table2, jointure avec le "catalogId" entre les deux tables) qui est égal a un paramètre de la procédure: @Email.

    J'ai tenté avec des Inner join... mais cela n'a pas l'air de fonctionner. Quelqu'un aurait une idée?

  2. #2
    Membre éclairé
    Inscrit en
    Octobre 2006
    Messages
    316
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 316
    Par défaut
    Et quelque chose du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT TOP(50) T1.DATE, T2.EMAIL FROM  TABLE 1 T1
     
    LEFT OUTER JOIN TABLE 2 T2
    ON T1.CATALOGUEID = T2.CATALOGUEID
     
    ORDER BY T1.DATE DESC

  3. #3
    Membre averti
    Développeur Web
    Inscrit en
    Janvier 2011
    Messages
    49
    Détails du profil
    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2011
    Messages : 49
    Par défaut
    Merci de ta réponse, mais elle n'est pas bonne malheuresement .

    Car cela doit être les 50 plus récentes lignes de la tables T1 mais qui ont l'email(de la tablt T2) égal à l'attribut @Email.

    La, ta requête va me retourner les 50 plus récentes lignes de la table t1 en affichant juste la date et l'email. Moi je souhaite avoir toutes les informations de la table t1, les 50 plus récentes, mais dont l'email de t2 est égal a @Email (la jointure se fait effectivement je pense par le catalogId de t1 et t2).

    Désolé si je n'avais pas été assez précis précédemment.

    Merci d'avance.

  4. #4
    Membre habitué
    Homme Profil pro
    Expert Base de Données
    Inscrit en
    Janvier 2009
    Messages
    16
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Expert Base de Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 16
    Par défaut
    La requète etait presque la bonne

    Avec tes compléments cela donne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT TOP(50) T1.DATE, T1.EMAIL FROM  TABLE 1 T1
     
    INNER JOIN TABLE 2 T2 ON T1.CATALOGUEID = T2.CATALOGUEID AND T1.EMAIL = T2.EMAIL
    ORDER BY T1.DATE DESC

  5. #5
    Membre Expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Par défaut
    Attention au JOIN qui 'dupliquera' vos lignes si vous avez 2 lignes dans table 2 répondant au critère de la jointure...

    Passez par un EXISTS...

Discussions similaires

  1. Réponses: 6
    Dernier message: 30/07/2011, 20h32
  2. Jointure avec les procédure stockée
    Par kaouane dans le forum Firebird
    Réponses: 7
    Dernier message: 13/12/2010, 10h59
  3. jointure entre procédure stocké
    Par Morad ISSOULGHANE dans le forum Développement
    Réponses: 2
    Dernier message: 28/10/2009, 13h36
  4. Explication procédure stockée
    Par underworld dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 09/09/2002, 10h51
  5. [Comparatif] Procédures stockées, triggers, etc.
    Par MCZz dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 28/08/2002, 12h27

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