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

WinDev Discussion :

Associer deux tables dans une troisième, REQ SQL


Sujet :

WinDev

  1. #1
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Avril 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Avril 2014
    Messages : 15
    Points : 0
    Points
    0
    Par défaut Associer deux tables dans une troisième, REQ SQL
    Bonjour,

    voici mon problème, j'ai fichiers de données, PRODUIT, COMPOSANT et LIAISON
    Les composants peuvent être dans plusieurs produits à la fois, j'aimerais afficher trois tables sur ma fenêtre,
    la première comporte tout les produits, en dessous, une seconde qui affiche les composants en fonction du produit sélectionné au dessus,
    et la troisième comportant IDPRODUIT et IDCOMPOSANT qui m'affiche toutes les liaisons entre les produits et les composants,
    par exemple:

    TABLE_LIAISON___ :

    IDPRODUIT | IDCOMPOSANT
    1 | 1
    1 | 2
    1 | 3
    2 | 2
    2 | 3
    3 | 1
    3 | 2

    J'aimerais si possible créer une requête SQL, mais je ne sais absolument pas comment.

  2. #2
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : Laos

    Informations forums :
    Inscription : Mars 2003
    Messages : 552
    Points : 1 193
    Points
    1 193

  3. #3
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Avril 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Avril 2014
    Messages : 15
    Points : 0
    Points
    0
    Par défaut
    D'accord merci j'ai réussi, mais comment faites vous pour vérifier si un couple d'ID est en doublon ?
    j'aimerais éviter ce problème en affichant un message, par exemple lorsque ma table contient :

    IDMODULE___|___IDCOMPOSANT
    _____1______|_____1________ <----
    _____1______|_____2________
    _____2______|_____1________
    _____2______|_____2________
    _____1______|_____1________ <----

    J'aimerais éviter les deux lignes suivis des flèches

  4. #4
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 278
    Points : 2 151
    Points
    2 151
    Par défaut
    GROUP BY pour grouper les lignes
    HAVING pour appliquer une restriction sur les groupes.
    SQL : le véritable Esperanto

    "Les patates à ta tata épatent ton tonton mais les pates aux thons à ton tonton épatent pas ta tata." (Michel Souris)

    MERCI DE NE PAS M'ENVOYER DE MESSAGE PRIVE POUR DES QUESTIONS TECHNIQUES SANS MON ACCORD !

  5. #5
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : Laos

    Informations forums :
    Inscription : Mars 2003
    Messages : 552
    Points : 1 193
    Points
    1 193
    Par défaut
    C'est une question de méthodologie.

    En amont :
    De manière générale lorsqu'on manipule une base de données, en cas d'ajout, suppression ou modification, la première chose à faire c'est un contrôle de saisie.

    Une bonne habitude est de découper par fonction votre travail.

    Une fonction "controleSaisie()" qui renvoi VRAI ou FAUX en fonction des différentes règles de gestions vérifier
    Une fonction "ajouteComposant(pIdProduit, pIdComposant)" qui se contente de faire un HAjoute() si le contrôle de saisie est correct.

    En aval (dans votre cas) :
    La solution de michel.souris va masquer l'incohérence de la base (enfin si pour vous c'est incohérent d'avoir plusieurs fois le même ID) au niveau IHM

    Mais si vous voulez être plus rigoureux, vous devez supprimer ces enregistrements erronés. Car si on lance une requête de somme, moyenne ou autres... le fait d'avoir masqué l'erreur va fausser les statistiques.
    Donc si vous ne pouvez pas modifier votre base de données comme bon vous semble, j'envisagerais une fonction supprimeDoublon() qui s'occuperait de rendre votre table de liaison cohérente.

  6. #6
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Avril 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Avril 2014
    Messages : 15
    Points : 0
    Points
    0
    Par défaut
    Oui c'est bien ça le soucis, je ne veut pas simplement les masquer de la table, je veux vraiment les supprimer de la BDD "LIAISON" pour éviter les doublons, car par la suite en cliquant sur un bouton, il va récupérer les infos dans la BDD "LIAISON" et soustraire le tout de mon stock de composant.

    je dois donc vérifier la présence de doublon avec quoi?

  7. #7
    Membre éprouvé
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    552
    Détails du profil
    Informations personnelles :
    Localisation : Laos

    Informations forums :
    Inscription : Mars 2003
    Messages : 552
    Points : 1 193
    Points
    1 193
    Par défaut
    Plusieurs algo plus ou moins complexe peuvent résoudre votre problème.

    Voici un exemple purement SQL :
    http://sqlpro.developpez.com/cours/doublons/

    Mais selon votre niveau de SQL et selon votre base de données, vous pouvez adapter une partie de la méthodologie en WLangage.

  8. #8
    Membre chevronné
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mars 2009
    Messages
    1 278
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 278
    Points : 2 151
    Points
    2 151
    Par défaut
    une requête de selection avec la clause having count(*)>1 vous permettra d'identifier les lignes à supprimer. Pour le reste vous devrez passer par du WLangage si vous travaillez sur des bases HF comme le dit Ry_Yo.

    Et surtout n'oubliez pas de traiter le problème en amont !
    SQL : le véritable Esperanto

    "Les patates à ta tata épatent ton tonton mais les pates aux thons à ton tonton épatent pas ta tata." (Michel Souris)

    MERCI DE NE PAS M'ENVOYER DE MESSAGE PRIVE POUR DES QUESTIONS TECHNIQUES SANS MON ACCORD !

  9. #9
    Nouveau Candidat au Club
    Homme Profil pro
    Architecte réseau
    Inscrit en
    Avril 2014
    Messages
    15
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Architecte réseau

    Informations forums :
    Inscription : Avril 2014
    Messages : 15
    Points : 0
    Points
    0
    Par défaut
    Est il possible de traduire ça en SQL svp?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    i est un entier
    POUR i = 1 A TABLE_Table2..Occurrence	
    	LIAISON.IDPRODUIT = TABLE_Table2.COL_IDPRODUIT[i]	
    	LIAISON.IDMODULE=TABLE_MODULE.COL_IDMODULE	
    	HAjoute(LIAISON) 
    FIN

Discussions similaires

  1. [VB6]Grouper les données des deux tables dans une troisième
    Par Abed_H dans le forum VB 6 et antérieur
    Réponses: 1
    Dernier message: 29/04/2009, 11h29
  2. Relier les champs de deux tables dans une interface graphique
    Par laurentlorient dans le forum Débuter
    Réponses: 1
    Dernier message: 26/04/2009, 22h34
  3. Create table dans une loop PL/SQL
    Par neo.51 dans le forum PL/SQL
    Réponses: 5
    Dernier message: 04/03/2009, 10h59
  4. UPDATE de deux tables dans une meme requete
    Par onizuka159 dans le forum Langage SQL
    Réponses: 4
    Dernier message: 21/05/2007, 14h09
  5. Formulaire affichant deux tables liées à une troisième
    Par Mimi-des-îles dans le forum Access
    Réponses: 1
    Dernier message: 23/02/2006, 13h47

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