public:std-3:cm2:interrogation_des_bases_de_donnees:3.2.2_operateurs_multi-tables

Principe : recoupement d'informations présentes dans plusieurs tables :

  • Croisement des critères de sélection : Jointure
  • Recherche ciblée : Division
Union de deux éléments :
  • Soient les relations r et s de schémas R et S.
  • On note R ⋂ S la liste des attributs communs aux deux schémas et R ⋃ S la liste des attributs appartenant à R ou à S.
  • soit t ∈ r et q ∈ s tels que t(R ⋂ S) = q(R ⋂ S)

On note t ⋃ q le tuple formé des valeurs de t et de q étendues au schéma R ⋃ S

Produit cartésien
  • Soient r et s (de schémas R et S), avec R ⋂ S = Ø

Le produit cartésien r × s est une nouvelle table de schéma R ⋃ S combinant les tuples de r et de s de toutes les façons possibles : $$r × s = \{t \cup q : t \in r, q \in s\}$$

  • La jointure est une opération qui consiste à effectuer un produit cartésien des tuples de deux relations pour lesquelles certaines valeurs correspondent.
  • Le résultat de l'opération est une nouvelle relation.
Jointure
  • Soient r et s (de schémas R et S), avec R ⋂ S ≠ Ø
  • La jointure r ⋈ s est une nouvelle table de schéma R ⋃ S combinant les tuples de r et de s ayant des valeurs communes pour les attributs communs.

$$r ⋈ s = \{t \cup q : t∈ r, q∈ s, t(R \cap S) = q(R \cap S)\}$$

Exemple

Matière_première :

nom_matièreunitéprix
pétrolebaril45$
gazGJ3$
uraniumlb12$

Exportations :

nom_paysnom_matièrequantité
Algériepétrole180.000
Algériegaz20.000
Nigeruranium30.000
Arabie Saouditepétrole2.000.000
Arabie Saouditegaz750.000

Matière_première ⋈ Exportations :

nom_paysnom_matièrequantitéunitéprix
Algériepétrole180.000baril45$
Algériegaz20.000GJ3$
Nigeruranium30.000lb12$
Arabie Saouditepétrole2.000.000baril45$
Arabie Saouditegaz750.000GJ3$

Exemples de requêtes

  • Donner la liste des PIB/hab des pays exportateurs de pétrole” :

$$Π_\text{PIB/hab}( σ_\text{nom_matière = pétrole} ( \text{Pays} ⋈ \text{Exportations} ))$$

Schéma de base relationnelle :
  • Clients ( nom_client, adresse_client, solde)
  • Commandes ( num_Commande, nom client, nom fournisseur, composant, quantité, montant)
  • Fournisseurs ( nom_fournisseur, adresse_fournisseur)
  • Catalogue ( nom_fournisseur, composant, prix )
  • Donner le nom et l'adresse des clients qui ont commandé des micro controleurs” :

$$Π_\text{nom_client,adresse_client}( σ_\text{composant = 'micro-controller'} ( \text{Client} ⋈ \text{Commandes} ))$$

SELECT    A1,A2,, An       // liste d’attributs
FROM      R1,, Rm          // liste de TABLES
WHERE     F1 ANDAND Fl    // liste de conditions sur les attributs 
                             // (en particulier conditions sur les attributs 
                             // sur lesquel  s’effectue la jointure)

Pour exprimer la jointure sur l’attribut 'Aj' commun aux tables 'R1' et 'R2', on écrira : 'R1.Aj = R2.Aj'

Exemples :

SELECT PIB_par_hab 
FROM Pays NATURAL JOIN Exportations
WHERE nom_matiere = 'petrole'
SELECT PIB_par_hab 
FROM Pays, Exportations
WHERE nom_matiere = 'petrole'
AND Pays.nom_pays = Exportations.nom_pays
SELECT PIB_par_hab 
FROM Pays
WHERE nom_pays IN (
  SELECT  nom_pays 
  FROM Exportations
  WHERE nom_matiere = 'petrole'
  )
Division
  • Soient r (de schémas R) et s (de schémas S), avec S ⊆ R :

La division r ÷ s est la relation (table) u de schéma R-S maximale contenant des tuples tels que u × s ⊆ r (avec × représentant le produit cartésien)

$$r ÷ s = \{ t | ∀ q ∈ s, t \cup q ∈ r\}$$

→ on cherche les éléments de t qui “correspondent” à s

Previous : 3.2.1 Opérateurs mono-table Up : Interrogation des bases de données Next : 3.2.3 Recherches composées

  • public/std-3/cm2/interrogation_des_bases_de_donnees/3.2.2_operateurs_multi-tables.txt
  • Dernière modification : 2018/01/17 13:26
  • de edauce