Le Langage d’Interrogation de Données LID Multi-table Jointures

Slides:



Advertisements
Présentations similaires
Le moteur
Advertisements

26/ 04/ 2007 Auto-Jointure : SELECT * FROM Nom_relation R1 INNER JOIN Nom_relation R2 ON Condition_de_jointure; Problèmes Si des attributs de même nom.
L’optimiseur ORACLE L’optimiseur ORACLE suit une approche classique: Génération de plusieurs plans d’exécution. Estimation du coût de chaque plan généré.
Bases de Données Avancées: Bases de Données Relationnelles
Évaluation des requêtes relationnelles
Est Ouest Sud 11 1 Nord 1 Individuel 20 joueurs 15 rondes - 30 étuis (arc-en-ciel) Laval Du Breuil Adstock, Québec I-20-15ACBLScore S0515 RondeNE
Est Ouest Sud 11 1 Nord 1 Laval Du Breuil, Adstock, Québec I-17-17ACBLScore S0417 Allez à 1 Est Allez à 4 Sud Allez à 3 Est Allez à 2 Ouest RndNE
Est Ouest Sud 11 1 Nord 1 Individuel 15 ou 16 joueurs 15 rondes - 30 étuis Laval Du Breuil Adstock, Québec I-16-15ACBLScore S0415 RndNE
Sud Ouest Est Nord Individuel 36 joueurs
Les Prepositions.
Jeudi 24/09 Correction TP du mardi 22/09
SQL - Subtilités.
Algèbre relationnelle
4 relations –EMPLOYE –SERVICE –LOCALITE –ADRESSE.
La diapo suivante pour faire des algorithmes (colorier les ampoules …à varier pour éviter le « copiage ») et dénombrer (Entoure dans la bande numérique.
Georges Gardarin 1 LE LANGAGE DE REQUETES SQL l Origines et Evolutions l SQL1 86: la base l SQL1 89: l'intégrité l SQL2 92: la nouvelle norme l SQL3 98:
Programme Introduction aux BD et aux SGBD Le modèle relationnel
Les Requêtes S.Q.L « Structured Query Language)
Les fonctions.
Les requêtes La Requête est une méthode pour afficher les enregistrements qui répondent à des conditions spécifiques. La requête est donc un filtre.
LMD: Langage de Manipulation de Données
Développement d’applications web
Eléments d ’algèbre relationnelle
Regrouper les Données avec les Fonctions de Groupe
Mise en œuvre du langage MDX - 1 ère partie- Présentation de lexemple et des outils utilisés -1-
Présentation du langage SQL / ORACLE
Langages du Web Sémantique
2 Ils associent les rangées de 2 requêtes UNION [ALL] INTERSECT MINUS.
SELECT {* | Expression [Alias] [,...] } FROM Table [WHERE Condition] [ORDER BY { Expression | Alias } [ ASC | DESC ] [NULLS FIRST | NULLS LAST ] [,...]
Conception d’une Base de Données Passage au Schéma Relationnel
L’utilisation des bases de données
Cours N°2 Base de Données & Langage SQL
1 LE LANGAGE DE REQUETES SQL Origines et Evolutions SQL1 86: la base SQL1 89: l'intégrité.
La Saint-Valentin Par Matt Maxwell.
Notre calendrier français MARS 2014
1 SQL Manipulations Avancées (08-09) Witold Litwin.
Manipulation des données Requêtes simples
C'est pour bientôt.....
Veuillez trouver ci-joint
Terrain Espérance Terrains Cézeaux T4T4 T1T1 T5T5 Matchs ext DU 06/08 au 12/ Mer 08Lun 06Mar 07Jeu 09Ven 10 10H 13H 15H 17H 18H 22H Sam 11Dim 12.
Les Nombres! de 0 à 20.
Atelier de formation : MAT optimisation II (les graphes).
EPID-CPI-ISAIP Philippe Bancquart - mise à jour 24/02/ page 1 SQL jointure PHILIPPE BANCQUART.
Limiter et trier des données
ECOLE DES HAUTES ETUDES COMMERCIALES MARKETING FONDAMENTAL
ECOLE DES HAUTES ETUDES COMMERCIALES MARKETING FONDAMENTAL
Traitement de différentes préoccupations Le 28 octobre et 4 novembre 2010.
ECOLE DES HAUTES ETUDES COMMERCIALES MARKETING FONDAMENTAL
* Source : Étude sur la consommation de la Commission européenne, indicateur de GfK Anticipations.
Le langage SQL LDD : Langage de Définition de Données
10 paires -. 9 séries de 3 étuis ( n° 1 à 27 ) 9 positions à jouer 5 tables Réalisé par M..Chardon.
Modélisation des données Niveau conceptuel DON-2 V0-0.
CALENDRIER-PLAYBOY 2020.
USAM BRIDGE H O W E L L -CLASSIQUE
6 Nombres et Heures 20 vingt 30 trente 40 quarante.
01. Liste des noms de candidats avec leur date de naissance.
Mise en œuvre du langage MDX
9 paires séries de 3 étuis ( n° 1 à 27 )
Les Chiffres Prêts?
 L’information est conservée sous forme de tables  Contient: ◦ Un nom ◦ Une clé primaire ◦ Une liste de colonnes ◦ Les informations/données (sous forme.
Le Langage d’Interrogation de Données LID Multi-table Jointures
Langage Relationnel Graphe de Requêtes
Le Langage de Manipulation de Données LMD. 2 Les ordres SQL de manipulation INSERT –Insertion (ajout) de ligne(s) dans une table –Utiliser SQL*LOAD pour.
Langage d’interrogation des Données LID
Transcription de la présentation:

Le Langage d’Interrogation de Données LID Multi-table Jointures

Les différentes méthodes de Jointure Opérateurs ensemblistes UNION, INTERSECT et MINUS Jointure en forme procédurale déconnectée SELECT imbriqués déconnectés Jointure en forme procédurale synchronisée SELECT imbriqués synchronisés Jointure en forme non procédurale ou relationnelle Pas d’imbrication : 1 seul bloc SELECT-FROM-WHERE Jointure complète ou externe (gauche ou droite) Requêtes hiérarchiques Parcours d’arbre : association réflexive 1-N

L’opérateur ensembliste UNION SELECT liste de colonnes FROM table1 UNION SELECT liste de colonnes FROM table2; SELECT idPro FROM produits_fabriques UNION SELECT codePro FROM produits_achetes; Même nombre de colonnes Mêmes types de colonnes Tri (ORDER BY) sur le n° de colonne Le DISTINCT est automatique

L’opérateur ensembliste INTERSECT SELECT liste de colonnes FROM table1 INTERSECT SELECT liste de colonnes FROM table2; SELECT idPro FROM produits_fabriques INTERSECT SELECT codePro FROM produits_achetes; Même nombre de colonnes Mêmes types de colonnes Tri (ORDER BY) sur le n° de colonne Le DISTINCT est automatique

L’opérateur ensembliste MINUS SELECT liste de colonnes FROM table1 MINUS SELECT liste de colonnes FROM table2; SELECT idService FROM service MINUS SELECT idService FROM employe; Attention à l’ordre des SELECT

Composition d’opérateurs ensemblistes SELECT liste de colonnes FROM table1 INTERSECT (SELECT liste de colonnes FROM table2 MINUS SELECT liste de colonnes FROM table3); Attention à l’ordre d’exécution  parenthèses

Jointure forme procédurale déconnectée imbrication de SELECT SELECT liste de colonnes(*) FROM table1 WHERE col1 [NOT] [IN] [<,>,!=,=,….][ANY|ALL] (SELECT col2 FROM table2 [WHERE prédicat ]); Col1 et col2 sont les colonnes de jointure [NOT] IN : si le sous-select peut ramener plusieurs lignes Ne sélectionne que des colonnes de la première table (*) Exécute d’abord le sous-select puis ‘remonte’ en respectant le graphe relationnel

Jointure forme procédurale déconnectée Exemple 1 : ouvrages empruntés SELECT titre,auteur FROM ouvrage WHERE idOuvrage IN (SELECT idOuvrage FROM emprunt WHERE dateEmprunt = SYSDATE AND idEtudiant IN (SELECT idEtudiant FROM etudiant WHERE ufr='Informatique')); Du select le plus imbriqué vers le select le plus haut Opérateur ‘IN’ obligatoire

Jointure forme procédurale déconnectée Exemple 2 : employés les mieux payés SELECT nom,fonction FROM emp WHERE salaire = (SELECT MAX(salaire) FROM emp); Le select imbriqué ne ramène qu’une valeur Signe ‘ =’ autorisé Cette forme est obligatoire pour obtenir ce résultat

Jointure forme procédurale déconnectée Exemple 3 : employé responsable SELECT nom,indice,salaire FROM emp WHERE idEmp = (SELECT idResp FROM emp WHERE idEmp=&idlu); Signe ‘=‘ autorisé Jointure réflexive

Jointure forme procédurale déconnectée Avantages et inconvénients Parfois obligatoire (exemple 2) Mise en œuvre naturelle du graphe de requêtes Affichage final : uniquement les colonnes de la première table Écriture lourde si le niveau d’imbrication est important : chemin d’accès à la charge du développeur Jointures Équi-jointures avec = ou IN Autres jointures (>,<, ….) ANY : au moins un élément (=ANY  IN) ALL : tous les éléments (!=ALL  NOT IN)

Jointure forme procédurale déconnectée Exemple 4 : ALL SELECT nom,indice,salaire FROM emp WHERE salaire > ALL (SELECT salaire FROM emp WHERE idService = 10); Employés gagnant plus que tous les employés du service 10 ? Requête plus ‘naturelle’ avec la fonction MAX …

Jointure en forme procédurale synchronisée Présentation Contrairement à la forme précédente, le sous-select est ‘synchronisé’ avec l’ordre du dessus (select ou update) Les deux ordres (dessus et dessous) fonctionnent comme deux boucles imbriquées Pour 1 pas de la boucle supérieure  n pas de la boucle inférieure SELECT ….. FROM table t1 WHERE ….. (SELECT ……. FROM table t2 WHERE t1.col1 = t2.col2); t1 t2

Jointure en forme procédurale synchronisée Exemple 1 Employés ne travaillant pas dans le même service que leur responsable ? EMPLOYE idEmp nomEmp idSer idResp SELECT e.nomEmp FROM emp e WHERE e.idSer != (SELECT r.idSer FROM emp r WHERE r.idEmp=e.idResp) AND e.idResp IS NOT NULL; 100 Jean 50 200 Sylvie 25 300 Xavier 400 Claude 30 500 Thomas nomEmp Jean Claude e r

Jointure en forme procédurale synchronisée Exemple 2 : UPDATE automatique Mise à jour automatique du nombre d’employés (nbEmp) de la table Service ? SERVICE idSer nomSer nbEmp UPDATE service s SET s.nbEmp = (SELECT COUNT(e.idEmp) FROM emp e WHERE e.idSer=s.idSer); 25 Info 3 30 Stat 1 50 Maths 60 Bd s e

Jointure en forme procédurale synchronisée Test d’existence : [NOT] EXISTS Le prédicat ‘EXISTS’ est ‘vrai’ si le sous-select ramène au moins une ligne NOT EXISTS  ensemble vide Permet de mettre en œuvre l’opérateur relationnel de DIVISION Principe : SELECT colonnes résultats FROM table1 t1 WHERE [NOT] EXISTS (SELECT {col | valeur} FROM table2 t2 WHERE t1.col1=t2.col2);

Jointure en forme procédurale synchronisée Exemple 3 : Test d’existence Les employés (nomEmp) travaillant dans un service contenant au moins un ‘programmeur’ ? EMPLOYE SELECT e1.nomEmp FROM emp e1 WHERE EXISTS (SELECT 'trouvé' FROM emp e2 WHERE e1.idSer=e2.idSer AND e2.fonction='programmeur'); idEmp nomEmp idSer fonction 100 Jean 50 concepteur 200 Sylvie 25 analyste 300 Xavier 400 Claude 30 500 Thomas programmeur nomEmp Sylvie Xavier Thomas

Jointure en forme procédurale synchronisée Mise en œuvre de la DIVISION DIVISION : un ensemble A est entièrement compris dans un autre (B) Un ensemble (A) est entièrement compris dans un autre (B) si : A – B = ou NOT EXISTS Égalité parfaite de 2 ensembles (A et B) si : A – B = et B – A =

Jointure en forme procédurale synchronisée Exemple 4 : DIVISION Étudiants (idEtu) inscrits aux mêmes UV que l’étudiant ‘100’ ? COURS SELECT c1.idEtu FROM cours c1 WHERE NOT EXISTS (SELECT c100.UV FROM cours c100 WHERE c100.idEtu=100 MINUS SELECT c2.UV FROM cours c2 WHERE c2.idEtu=c1.idEtu) AND c1.idEtu <> 100; idEtu UV 100 UV1 200 UV3 300 UV4 UV2 idEtu 300

Jointure en forme Relationnelle Pas d’imbrication, colonnes résultats de toutes les tables intervenant Le chemin d’accès (graphe) est à la charge du SGBD Un seul bloc SELECT – FROM – WHERE Présentation d’une EQUI-JOINTURE : SELECT colonnes résultats (des 3 tables) FROM table1 t1, table2 t2, table3 t3 WHERE t1.col1=t2.col2 AND t2.col2=t3.col3; N tables  N-1 Jointures

Jointure en forme Relationnelle Exemple 1 : ouvrages empruntés Reprise du 1er exemple de la forme procédurale BREAK ON nom SELECT et.nom,o.titre,o.auteur FROM ouvrage o, emprunt ep, etudiant et WHERE et.ufr='Informatique' AND et.idEtudiant=ep.idEtudiant AND ep.dateEmprunt = SYSDATE AND ep.idOuvrage=o.idOuvrage ORDER BY 1,2; CLEAR BREAK Colonnes de tables différentes : impossible en procédural

Jointure en forme Relationnelle Exemple 2 : employé responsable Nom de l’employé responsable d’un employé ? SET HEADING OFF ACCEPT idlu PROMPT 'Entrer le n° employé:' SELECT er.nom||'Responsable de'||ee.nom FROM emp er, emp ee WHERE er.idEmp = ee.idResp AND ee.idEmp = &idlu; SET HEADING ON

Jointure en forme Relationnelle Exemple 3 : autre jointure Autre jointure que l’ EQUI-JOINTURE Employés gagnant plus que ‘Michel’ ? COLUMN n HEADING 'Nom employé' COLUMN s1 HEADING 'Son salaire' COLUMN s2 HEADING 'Salaire de Michel' SELECT e.nom as n,e.salaire as s1, m.salaire as s2 FROM emp e, emp m WHERE m.nom='Michel' AND e.salaire > m.salaire; CLEAR COLUMNS

Jointure en forme Relationnelle Jointure Externe ou Complète Lignes de l’EQUI-JOINTURE plus les lignes n’ayant pas de correspondantes (+) Équivalent du LEFT JOIN de certains SGBD, OUTER JOIN pour Oracle SELECT s.nomSer AS 'Nom du Service', e.nomEmp AS 'Employés' FROM emp e, service s WHERE s.idSer = e.idSer(+); Nom du Service Employés Info Michel jean Stat xavier Bd Aucun employé (valeur nulle)

Jointure Externe ou Complète Exemple d’utilisation Services n’ayant pas d’employés ? SELECT s.nomSer AS 'Nom du Service' FROM emp e, service s WHERE s.idSer = e.idSer(+) AND e.idEmp IS NULL;

7 Façons de résoudre une requête …… Étudiants (nom) ayant emprunté un ouvrage particulier (&ouvlu) ? SELECT e.nom FROM etudiant e WHERE e.idEtu IN (SELECT ep.idEtu FROM emprunt ep WHERE ep.idOuv = '&ouvlu'); 1 SELECT e.nom FROM etudiant e WHERE e.idEtu = ANY (SELECT ep.idEtu FROM emprunt ep WHERE ep.idOuv = '&ouvlu'); 2

7 Façons de résoudre une requête (suite) SELECT e.nom FROM etudiant e WHERE EXISTS (SELECT 'trouvé' FROM emprunt ep WHERE ep.idOuv = '&ouvlu‘ AND e.idEtu = ep.idEtu); 3 SELECT e.nom FROM etudiant e, emprunt ep WHERE ep.idOuv = '&ouvlu' AND e.idEtu = ep.idEtu; 4

7 Façons de résoudre une requête (suite) SELECT e.nom FROM etudiant e WHERE 0 < (SELECT COUNT(*) FROM emprunt ep WHERE ep.idOuv = '&ouvlu' AND e.idEtu = ep.idEtu); 5 SELECT e.nom FROM etudiant e WHERE '&ouvlu' IN (SELECT ep.idOuv FROM emprunt ep WHERE e.idEtu = ep.idEtu); 6

7 Façons de résoudre une requête (fin) SELECT e.nom FROM etudiant e WHERE '&ouvlu' = ANY (SELECT ep.idOuv FROM emprunt ep WHERE e.idEtu = ep.idEtu); 7 Je préfère la 4 !!