Algèbre relationnel
Résolu
MEFTAH
Messages postés
18
Statut
Membre
-
flokocha Messages postés 1519 Statut Membre -
flokocha Messages postés 1519 Statut Membre -
Bonjour
soit :
Les_Entrees ( Code_Article , Quantite )
1 20
2 11
4 5
Les_Sorties ( Code_Article , Quantite )
1 10
2 15
3 2
Je voudrai une requette SQL qui permet d'obtenir un résultat qui resemble à ceci :
Code Article Qt_Entrée Qt_Sortie
1 20 10
2 11 15
3 0 2
4 5 0
Comment faire SVP et Merci d'avance.
soit :
Les_Entrees ( Code_Article , Quantite )
1 20
2 11
4 5
Les_Sorties ( Code_Article , Quantite )
1 10
2 15
3 2
Je voudrai une requette SQL qui permet d'obtenir un résultat qui resemble à ceci :
Code Article Qt_Entrée Qt_Sortie
1 20 10
2 11 15
3 0 2
4 5 0
Comment faire SVP et Merci d'avance.
A voir également:
- Ora-00920: opérateur relationnel non valide
- Ethernet n'a pas de configuration ip valide - Guide
- Opérateur de réseau mobile - Guide
- 0644 quel opérateur ✓ - Forum Mobile
- 0668 quel opérateur ✓ - Forum Opérateurs & Réseaux mobiles
- 0466 quel opérateur - Forum Mobile
2 réponses
Bonjour,
Avec une jointure .....
Un truc du genre :
Avec une jointure .....
Un truc du genre :
SELECT E.Code_Article, E.Quantite as Qte_entree, S.Quantite as Qte_sortie FROM Qt_Entrée E LEFT JOIN Qt_Sortie S ON S.Code_Article = E.Code_Article
Salut,
Une jointure utilisant un LEFT JOIN ne pourrait pas produire la ligne numéro 3 de son résultat donné en exemple.
Étant donné qu'on veut retourner les résultats des deux tables, indépendamment du fait qu'ils soient présents dans l'une ou dans l'autre ce ces tables, il faut utiliser un FULL OUTER JOIN.
Ce qui donnerait donc (avec l'utilisation de la fonction IFNULL() pour afficher 0 au lieu de null dans le cas où une entrée n'existe pas dans une des deux tables) :
Une jointure utilisant un LEFT JOIN ne pourrait pas produire la ligne numéro 3 de son résultat donné en exemple.
Étant donné qu'on veut retourner les résultats des deux tables, indépendamment du fait qu'ils soient présents dans l'une ou dans l'autre ce ces tables, il faut utiliser un FULL OUTER JOIN.
Ce qui donnerait donc (avec l'utilisation de la fonction IFNULL() pour afficher 0 au lieu de null dans le cas où une entrée n'existe pas dans une des deux tables) :
SELECT Code_Article, IFNULL(E.Quantite, 0) as Qte_entree, IFNULL(S.Quantite, 0) as Qte_sortie FROM Qt_Entrée E FULL OUTER JOIN Qt_Sortie S USING(Code_Article)
Ok au temps pour moi !
Dans ce cas il va falloir simuler le mode de fonctionnement de ce FULL OUTER JOIN qu'on ne peut pas utiliser. Le fait qu'il puisse y avoir plusieurs entrées dans une tables pour un même article va aussi changer un peu les choses en nous obligeant à calculer préalablement la somme pour chaque article dans chacune des deux tables.
Je te propose donc de procéder comme ceci :
- Calculer la somme des entrées de chaque article > E
- Calculer la somme des sorties de chaque article > S
- Récupérer les valeurs pour les articles présents dans E et S
- Récupérer les valeurs pour les articles présents dans E mais pas dans S
- Récupérer les valeurs pour les articles présents dans S mais pas dans E
- Faire l'union de ces 3 requêtes
Ce qui donne :
Dans ce cas il va falloir simuler le mode de fonctionnement de ce FULL OUTER JOIN qu'on ne peut pas utiliser. Le fait qu'il puisse y avoir plusieurs entrées dans une tables pour un même article va aussi changer un peu les choses en nous obligeant à calculer préalablement la somme pour chaque article dans chacune des deux tables.
Je te propose donc de procéder comme ceci :
- Calculer la somme des entrées de chaque article > E
- Calculer la somme des sorties de chaque article > S
- Récupérer les valeurs pour les articles présents dans E et S
- Récupérer les valeurs pour les articles présents dans E mais pas dans S
- Récupérer les valeurs pour les articles présents dans S mais pas dans E
- Faire l'union de ces 3 requêtes
Ce qui donne :
SELECT Code_Article, E.Q AS EQ, S.Q AS SQ FROM (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Entrees GROUP BY 1) AS E INNER JOIN (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Sorties GROUP BY 1) AS S USING(Code_Article) UNION SELECT Code_Article, E.Q AS EQ, 0 AS SQ FROM (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Entrees GROUP BY 1) AS E LEFT JOIN (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Sorties GROUP BY 1) AS S USING(Code_Article) WHERE S.Code_Article IS NULL UNION SELECT Code_Article, 0 AS EQ, S.Q AS SQ FROM (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Entrees GROUP BY 1) AS E RIGHT JOIN (SELECT Code_Article, SUM(Quantite) AS Q FROM Les_Sorties GROUP BY 1) AS S USING(Code_Article) WHERE E.Code_Article IS NULL ORDER BY Code_Article