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

Langage SQL Discussion :

Select distinct entre deux tables


Sujet :

Langage SQL

  1. #1
    Membre du Club
    Inscrit en
    Mai 2003
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 108
    Points : 62
    Points
    62
    Par défaut Select distinct entre deux tables
    Salut a tous,

    je voudrais par une requete resortir tous les vendeurs,leur adresse ,telephone ,ville et pays en sachant qu'il provienne de deux tables differentes qui ont le champ vendeur en commun.Quand je lis les 2tables en utilisant un select distinct ou un goup by je recoit un message d'erreur . Et sans les utiliser tous les enregistrement s'affiche avec les redondances quelqu'un peut il m'aider

    T1.code_V T1.Vendeur T2.Adresse T1.telephone T2.ville T1.Pays
    111 Titi Bvd 000001 Paris1 France
    112 Titi Bvd 000001 Paris1 France
    113 fifi abc 000003 Paris4 France
    114 loulou efg 000004 Nice France
    115 loulou efg 000004 Nice France
    116 riri ard 000007 Nante France
    118 Titi Bvd 000001 Paris1 France



  2. #2
    Expert éminent
    Avatar de StringBuilder
    Homme Profil pro
    Chef de projets
    Inscrit en
    Février 2010
    Messages
    4 170
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Chef de projets
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2010
    Messages : 4 170
    Points : 7 421
    Points
    7 421
    Billets dans le blog
    1
    Par défaut
    tu peux poster ta requête ?

    avec et sans le distinct.

    (évite de faire des distinct avec un group by, vu que ça sert pas à ça, tu pourrais avoir des surprises, d'autant que la norme n'impose pas de suppression des doublons par l'utilisation du group by -pas plus que le tri d'ailleurs-)

  3. #3
    Membre du Club
    Inscrit en
    Mai 2003
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 108
    Points : 62
    Points
    62
    Par défaut
    salut,
    mon objectif avec cette requète est de pouvoir sortir tous les vendeur contenu dans la table vente et pouvoir les lier avec les informations contenu dans la table identité (qui contient les adresses telephone et autres...)sans avoir de doublons(car un vendeur peut avoir fait plusieurs ventes).
    Dois-je faire cette requète en imbriquant plusieurs Select ou dois-je la faire avec un select distinct ?
    merci pour votre aide .

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Je suppose que la table 'identite' contient l'identifiant des vendeurs ?

    Et que dans cette table, chaque vendeur n'est présent qu'une fois ?

    Dès lors, pourquoi as-tu besoin de la table 'vente' ?
    Tu ne veux que les vendeurs ayant fait au moins une vente ?

    Donne nous la structure de tes tables et la ou les requêtes que tu as essayées.

  5. #5
    Membre du Club
    Inscrit en
    Mai 2003
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 108
    Points : 62
    Points
    62
    Par défaut
    salut,
    je reformule mon probleme.j'ai deux tables qui contiennent des informations dont j'ai besoin pour former un nouvelle table t1:Vente ( code_vente code_vendeur , num_produit, nom_vendeur, adresse_vendeur) t2:livraison (code_livraison, code_vendeur, telephone_vendeur, telefone_client, adresse_client,date_dembauche_vendeur).
    Et maintenant je voudrais créer une table t3 (code_vendeur,nom_vendeur, adresse_vendeur,telephone_vendeur,date_dembauche_vendeur). Sans oublier que dans t1 et t2 code_vendeur n'est pas la clé.Un vendeur n'a qu'un seul code_vendeur. Dans T3 code_vendeur sera la clé unique.
    Mon but pour créer cette table etai de faire un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select distinct t1.code_vendeur, t1.nom_vendeur, t1.adresse_vendeur, 
      t2.telephone_vendeur,t2.date_dembauche_vendeur 
    from T1 
    inner join t2 on t1.code_vendeur=t2.code_vendeur
    Mais malheuresement il me ressort des redondances au niveau des vendeur.
    merci de votre aide

  6. #6
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Citation Envoyé par kssillati Voir le message
    Mais malheuresement il me ressort des redondances au niveau des vendeur.
    Tu veux dire que certains vendeurs apparraissent plusieurs fois ?
    Ca voudrait dire qu'un vendeur peut avoir plusieurs adresses ou plusieurs téléphones.

    Donne nous des exemples de données en modifiant les infos personnelles réelles.

  7. #7
    Membre du Club
    Inscrit en
    Mai 2003
    Messages
    108
    Détails du profil
    Informations forums :
    Inscription : Mai 2003
    Messages : 108
    Points : 62
    Points
    62
    Par défaut
    salut,
    voici a peu près comment se présente mes deux tables ,Vente et livraison

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    t1.code_vente, t1.code_vendeur ,  t1.num_produit,   t1.nom_vendeur,    t1.adresse_vendeur
    10            1001              300010            Paul             BV Paris1
    11            1001              300014            Paul             BV Paris1
    12            1002              300010            Pierre           PR Nice
    13            1003              300015            Jean            BV Nante
    14            1002              300020            Pierre           PR Nice
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    T2.code_livraison,  t2.code_vendeur, t2. telephone_vendeur,  t2.telefone_client,  t2. adresse_client,  t2.date_dembauche_vendeur
    2001              1001             001203040           224411           Paris1Pv       20080101 
    2002              1001             001203040           224415          Bordeau10     20080101 
    2003              1002             001203045           224422          Havre22        20070201
    2004              1003             001203040           224444          Nante33        20090501
    2005              1002             001203045           224455          Nice22         20070201
    merci pour l'aide

  8. #8
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 048
    Points
    34 048
    Billets dans le blog
    14
    Par défaut
    Dans ton exemple de données, je ne vois aucune redondance !
    Avec cet exemple de données, ta requête faisant un DISTINCT ne devrait te donner qu'une ligne par vendeur.

Discussions similaires

  1. Réponses: 5
    Dernier message: 09/03/2012, 10h31
  2. Copie de données entre deux tables distinctes
    Par newty dans le forum Requêtes
    Réponses: 7
    Dernier message: 30/07/2010, 16h25
  3. Réponses: 4
    Dernier message: 09/11/2007, 18h08
  4. [SELECT] sélection croisée entre deux tables
    Par WriteLN dans le forum Langage SQL
    Réponses: 4
    Dernier message: 22/03/2005, 11h05
  5. Jointure entre deux tables et résultat
    Par Asdorve dans le forum Langage SQL
    Réponses: 2
    Dernier message: 02/06/2004, 14h50

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