Cours 4: Optimisation - PowerPoint PPT Presentation

About This Presentation
Title:

Cours 4: Optimisation

Description:

Cours 4: Optimisation & Normalisation Tuanloc NGUYEN Miage de Paris 12 Optimisation de requ tes Alg bre relationnel D composition de la requ te Optimisation ... – PowerPoint PPT presentation

Number of Views:222
Avg rating:3.0/5.0
Slides: 59
Provided by: nguyentu
Category:

less

Transcript and Presenter's Notes

Title: Cours 4: Optimisation


1
Cours 4 Optimisation Normalisation
  • Tuanloc NGUYEN
  • Miage de Paris 12

2
Optimisation de requêtes
  • Algèbre relationnel
  • Décomposition de la requête
  • Optimisation

3
Architecture SGBD
Schéma Vue Autorisation Intégrité Ordonnancem
ent Élaboration/ Optimisation Méthode
daccès (hachage,arbre B,index)
ANALYSEUR
CONTROLE
META-BASE
Traitement
EXECUTABLE
BD
4
Traitement dune requête
SQL
Normalisation
Analyse
Processeur de requêtes
Simplification
Restructuration
Optimisation
Exécution des plans
5
Rappel sur lalgèbre relationnel
  • Normalisation
  • Forme conjonctive
  • (p11 ? p12 vv p1n) ? (pm1 ? pm2 vv pmn)
  • Forme disjonctive
  • (p11 ? p12 ? ? p1n) v (pm1 ? pm2 ?? pmn)
  • (souvent disjonctive)

6
Exemple schéma de la base de données pour les
étudiants de la MIAGE Paris 12
7
Conjonctive
  • SELECT ENSEIGNANTS.nom, ENSEIGNANTS.prenom,
    MATIERES.nommat
  • FROM MATIERES INNER JOIN (ENSEIGNANTS INNER JOIN
    ENSEIGN_MAT ON ENSEIGNANTS.codens
    ENSEIGN_MAT.codens) ON MATIERES.codemat
    ENSEIGN_MAT.codemat
  • WHERE (((ENSEIGNANTS.nom)"NGUYEN")
  • AND ((MATIERES.nommat)"ACCESS" Or
    (MATIERES.nommat)"BASE DE DONNEES"))

8
Disjonctive
  • SELECT ENSEIGNANTS.nom, ENSEIGNANTS.prenom,
    MATIERES.nommat
  • FROM MATIERES INNER JOIN (ENSEIGNANTS INNER JOIN
    ENSEIGN_MAT ON ENSEIGNANTS.codens
    ENSEIGN_MAT.codens) ON MATIERES.codemat
    ENSEIGN_MAT.codemat
  • WHERE ( ( (ENSEIGNANTS.nom)"NGUYEN" AND
    (MATIERES.nommat)"BASE DE DONNEES")
  • OR ( (MATIERES.nommat)"ACCESS" AND
    (MATIERES.nommat)"BASE DE DONNEES"))

9
Normalisation de requête
  • p1 ? p2 lt gt p2 ? p1
  • p1 v p2 lt gt p2 v p1 (commutativité)
  • p1?(p2 ? p3) lt gt p1?p2?p3
  • p1v(p2 v p3) lt gt p1vp2vp3 (associativité)
  • p1?(p2vp3) lt gt(p1?p2)v(p1?p3)
  • p1v(p2?p3) lt gt(p1vp2) ?(p1vp3)
  • !(p1 ? p2) lt gt!p1 v !p2
  • !!(p) lt gt p

10
Exercice
  • SELECT Title
  • FROM Emp
  • WHERE (Not (Titlelinux)
  • AND (Titlelinux
  • OR Titlewindows)
  • AND Not (Title unix))
  • OR Ename Toward Linus
  • On suppose
  • p1 Titlelinux
  • p2 Titlewindows
  • p3 Ename Toward Linus

11
Forme normale
  • (!p1 ? (p1 v p2) ? !p2) v p3
  • Disjonctive
  • (!p1 ? p1) v (!p1 ?p2) ? !p2) v p3lt gt
  • (!p2 ? (!p1 ? p1) v (!p1 ?p2)) v p3lt gt
  • (!p2?(!p1 ? p1))v(!p2?(!p1?p2)) v p3
  • lt gt(!p2?!p1?p1)v(!p2?!p1?p2) v p3
  • lt gt(!p2 ?false) v (!p1 ? false) v p3
  • lt gt false v false v p3
  • lt gt p3

12
Requête finale
  • SELECT Title
  • From Emp
  • WHERE Ename Toward Linus

13
Règle de transformation
  • Commutativité
  • R x S ? S x R
  • R x S ? S x R
  • R U S ? S U R
  • Associativité
  • ( R x S ) x T R x ( S x T)
  • ( R x S ) x T R x ( S x T)
  • Idempotence
  • ?A (?A(R) ) ?A(R) (avec A dans A)

14
Analyse
  • Mise de la requête en forme normale
  • Analyse lexical et syntaxique
  • Type incorrect ou inexistant (schéma de la
    relation)

15
Simplification
  • p ? p lt gt p
  • p v p lt gt p
  • p ? true lt gtp
  • p v false lt gt p
  • p ? false lt gt false
  • p v true lt gt true
  • p ? !p lt gt false
  • p v !p lt gt true
  • p1 ? (p1 v p2) lt gt p1
  • P1 v (p1 ? p2) lt gt p1

16
Simplification
  • Plus une requête est simple, plus son exécution
    peut être efficace

17
Implémentation
  • Sélection
  • Parcours séquentiel
  • Parcours avec index (hachage,arbre B)
  • Projection
  • Jointure T R x S
  • foreach tuple r ? R do
  • foreach tuple s ? S do
  • if rs
  • T T ltr,sgt

18
Restructuration
  • Objectif choisir lordre de lexécution des
    opérations algébriques (élaboration du plan
    logique)
  • Conversion en arbre algébrique
  • Transformation de larbre (optimisation)
  • Appliquer les règles de transformation
  • Estimation du coût des opérations (taille)
  • Ordre des jointures (coûte le plus cher)

19
  • SELECT ENSEIGNANTS.nom, ENSEIGNANTS.prenom,
    MATIERES.nommat, ENSEIGNANTS.note,
    ENSEIGNANTS.gentil
  • FROM MATIERES INNER JOIN ENSEIGNANTS INNER JOIN
    ENSEIGN_MAT
  • ON ENSEIGNANTS.codensENSEIGN_MAT.codens
  • ON MATIERES.codemat ENSEIGN_MAT.codemat
  • WHERE ENSEIGNANTS.note20
  • AND ENSEIGNANTS.gentil"top"
  • AND
  • (nommat"ADMIN BASE DE DONNEES"OR
    nommat"ACCESS")

20
Arbre algébrique
RESULTAT
Nom,Prénom,Note,gentil
nommat"ADMIN BASE DE DONNEES"OR nommat"ACCESS"
ENSEIGNANTS.gentil"top"
ENSEIGNANTS.note20
ENSEIGN_MAT.Codemat
MATIERES.Codemat

MATIERES
ENSEIGN_MAT.Codens
ENSEIGNANTS.Codens

ENSEIGN_MAT
ENSEIGNANTS
21
Optimisation
  • Elaborer des plans
  • Arbre algébrique, restructuration, ordre
    dévalution
  • Estimer les coûts
  • Temps dexécution
  • Coût I/O, CPU, poids entre I/O CPU
  • Nombre dinstructions et daccès au disque
  • Choisir le meilleur plan
  • Algorithme de recherche Heuristique
  • Coût de chaque plan est différent
  • Ordre des jointures est très important
  • Optimisation despace de recherche
  • Stratégie de recherche
  • Déterministe
  • Aléatoire efficace avec beaucoup de relations,
    améliorer itinéraire

22
Optimisation
  • Pour optimiser, il y a une technique simple
    descendre les opérateurs de sélection et
    projection le plus près possible des feuilles
    pour réduire les tables le plus possible

23
Arbre optimisé
RESULTAT
nommat"ADMIN BASE DE DONNEES"OR nommat"ACCESS"
ENSEIGNANTS.gentil"top"
ENSEIGNANTS.note20
ENSEIGN_MAT.Codemat
MATIERES.Codemat

MATIERES
ENSEIGN_MAT.Codens
ENSEIGNANTS.Codens

ENSEIGN_MAT
Nom,Prénom,Note,gentil
ENSEIGNANTS
24
Conclusion
  • Très important pour administrateur de base de
    données
  • améliorer les performances en réglant des
    paramètres pour optimiser des requêtes

25
Normalisation
  • 1NF
  • 2NF
  • 3NF
  • BCNF
  • 4NF

Données non-normalisation
3 NF
2 NF
BCNF
1 NF
4 NF
5 NF
26
Pourquoi normalisation ?
27
Première forme normale 1NF
  • Une relation est dite normalisée ou en première
    forme normale si
  • aucun attribut qui la compose n'est lui-même une
    relation, c'est-à-dire si tout attribut est
    atomique (non décomposable).
  • Cette forme n'utilise que les structures de base
    d'une relation, elle ne résout pas le problème de
    la redondance.

28
Exemple 1NF
  • R(code_etudiant,nom,prénom,code_mat1,code_mat2,co
    de_mat3,code_mat4,code_mat5)
  • -gt ce nest pas bien

S code de fournisseur
sname nom de fournisseur
fournisseur
status statut de fournisseur
p produit
R(s,p,sname,city,status,qty)
29
R(s,p,sname,city,status,qty)
S1 P1 A C1 1 10
S1 P2 A C1 1 20
S1 P3 A C1 1 25
S1 P4 A C1 1 30
S2 P1 B C1 1 15
S1 P2 B C1 1 40
S3 P1 C C2 2 5
S4 P1 D C2 2 35
S5 P2 E C3 3 7
30
  • Problème
  • Ajouter S6 pas de produit ?
  • Changer nom S1 a en x
  • Changer tous S1
  • Changer 1 enregistrement conflit
  • -gtredondance
  • Supprimer S3 perde dinfo S3

31
Sections de données répétées imbriquées
Table (Key1, . . . (Key2, . . . (Key3, . . .) ) )
Table1(Key1, . . .)
TableA (Key1,Key2 . . .(Key3, . . .) )
Table2 (Key1, Key2 . . .)
Table3 (Key1, Key2, Key3, . . .)
  • Première forme normale (1NF)
  • Table1(Key1, aaa . . .)
  • Table2(Key1, Key2, bbb . .)
  • Table3(Key1, Key2, Key3, ccc. . .)

32
Deuxième forme normale 2NF
  • Une relation est dite en deuxième forme normale
    si et seulement si
  • Elle est en première forme normale
  • Chaque attribut est totalement dépendant de la
    clé primaire.
  • Avec cette forme, les problèmes de redondance ne
    sont pas entièrement résolus.

33
Exemple 2NF
R(s,p,sname,city,status,qty)
R1(s,p,sname,city,status)
R2(s,p,qty)
Information de la société
Activité de la société
34
2NF
S1 P1 10
S1 P2 20
S1 P3 25
S1 P4 30
S2 P1 15
S1 P2 40
S3 P1 5
S4 P1 35
S5 P2 7
PAS DE PROBLEMES
35
Troisième forme normale 3NF
  • Une relation est en troisième forme normale si et
    seulement si
  • elle est en 2NF
  • et chaque attribut non-clé primaire dépend
    directement de la clé primaire.
  • La 3NF est adéquate pour la majorité des designs
    de BD mais elle n'élimine pas toutes les
    redondances et incohérences. Pour cela, Codd a
    pensé à BCNF qui est une forme plus stricte de
    3NF.

36
Exemple 3NF
R11(city, status) 3NF
R1
R12(s, sname,city) 3NF
R
R2 (s,p,qty) 3NF
3NF TR11, R12, R2
Solution
sname
1) s
city
Enlever s -gtstatus
X
status
2) R12
R121
R122
37
Quatrième forme normale 4NF
  • Permet autant que possible de minimiser
    l'occurence d'attributs indépendants à valeur
    mutiple.
  • Une relation est de la 4NF si
  • elle satisfait la 3NF
  • les données composant chaque attribut ne
    comportent aucune répétition inutile -gt dans une
    même colonne, il faut minimiser les répétitions.
  • Une base qui est 4NF est des plus optimales
    quoiqu'il soit possible de généraliser cette
    dernière afin d'obtenir la 5NF.

38
Boyce-Codd Normal Form (BCNF)
  • Dépendances fonctionnelles cachées
  • Exemple
  • Employee-Specialty(E, Specialty, Manager)
  • Est en 3NF.
  • Rêgle dentreprise Business rules.
  • Un employé peut avoir plusieurs spécialités.
  • Chaque spécialité a plusieurs managers.
  • Chaque managera seulement une spécialité.
  • Un employé a seulement 1 manager pour chaque
    spécialité.
  • Le problème est dans la dépendance fonctionnelle
    caché entre manager et spécialité.
  • Besoin dune table séparée pour manager.
  • But then we dont need to repeat specialty.
  • Dans monde réel, la duplication serait
    probablement acceptée (spécialité dans les 2
    tables.

Employee-Specialty(E, Specialty, Manager)
Employee(E, Manager)
Manager(Manager, Specialty)
Employee(E, Specialty, Manager)
Manager(Manager, Specialty)
acceptable
39
  • Annexe Normalisation

40
Exemple BD Video
Clé possible
Section de données répétées
41
Objets de la BD Vidéo
  • Clients
  • Clé Assignation de CustomerID
  • Propriétés
  • Nom
  • Adresse
  • Téléphone
  • Vidéos
  • Clé Attribution dun noVidéo
  • Propriétés
  • Titre
  • PrixLocation
  • Cote
  • Description
  • TransactionLocation
  • Relation/Événement
  • Clé Attribution dun noTransaction
  • Propriétés
  • noClient
  • Date
  • VidéosLoués
  • Événement/Liste
  • Clés noTransaction noVidéo
  • Propriétés
  • noCopieVidéo

42
Formulaire initial BD vidéo
RentalForm(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode, (VideoID
, Copy, Title, Rent ) )
  • Recueillir les formulaires de lusager
  • Noter les propriétés
  • Trouver les sections de données répétées
  • Noter les clés potentielles
  • Identifier les propriétés calculées
  • Résultat équivalent à un diagramme (modèle
    logique), mais va pouvoir être contenu sur un
    page ou deux.

43
Problèmes avec les sections de données répétées
RentalForm(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode, (VideoID
, Copy, Title, Rent ) )
Beaucoup de problèmes seraient provoqués par
cette structure.
Section de données répétées
Provoque des duplications
TransID RentDate CustomerID LastName Phone Address
VideoID Copy Title Rent 1 4/18/02 3 Washington
502-777-7575 95 Easy Street 1 2 2001 A Space
Odyssey 1.50 1 4/18/02 3 Washington 502-777-7575
95 Easy Street 6 3 Clockwork Orange 1.50 2 4/30/
02 7 Lasater 615-888-4474 67 S. Ray
Drive 8 1 Hopscotch 1.50 2 4/30/02
7 Lasater 615-888-4474 67 S. Ray
Drive 2 1 Apocalypse Now 2.00 2 4/30/02
7 Lasater 615-888-4474 67 S. Ray
Drive 6 1 Clockwork Orange 1.50 3 4/18/02 8 Jones
615-452-1162 867 Lakeside Drive 9 1 Luggage Of
The Gods 2.50 3 4/18/02 8 Jones 615-452-1162 867
Lakeside Drive 15 1 Fabulous Baker
Boys 2.00 3 4/18/02 8 Jones 615-452-1162 867
Lakeside Drive 4 1 Boy And His Dog 2.50 4 4/18/02
3 Washington 502-777-7575 95 Easy
Street 3 1 Blues Brothers 2.00 4 4/18/02
3 Washington 502-777-7575 95 Easy
Street 8 1 Hopscotch 1.50 4 4/18/02
3 Washington 502-777-7575 95 Easy
Street 13 1 Surf Nazis Must Die 2.50 4 4/18/02 3
Washington 502-777-7575 95 Easy
Street 17 1 Witches of Eastwick 2.00
44
Problèmes avec les sections de données répétées
  • Autre idée Mémoriser les données sur la largeur
    ()
  • Allocation despace
  • Combien?
  • Ne peut être petit
  • Perte despace
  • e.g., Combien de vidéo seront loué ?
  • Une meilleure définition élimine ces problèmes.

Name Phone Address City State ZipCode
Customer Rentals
VideoID Copy Title Rent 1. 6 1 Clockwork
Orange 1.50 2. 8 2 Hopscotch 1.50 3. 4. 5.
Unused Space
Pas en première forme normale
45
Première forme normale
RentalForm(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode,
(VideoID, Copy, Title, Rent ) )
RentalForm2(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode)
RentalLine(TransID, VideoID, Copy, Title, Rent )
  • Enlever les sections de données répétées
  • Divisé en 2 tables
  • Transmettre les clés de la table principale à la
    nouvelle table
  • RentalLine(TransID, VideoID, Copy, . . .)
  • Chaque transaction peut avoir plusieurs vidéos
    (clé VideoID)
  • Chaque vidéo peut être loué dans plusieurs
    transactions

46
Sections de données répétées imbriquées
Table (Key1, . . . (Key2, . . . (Key3, . . .) ) )
Table1(Key1, . . .)
TableA (Key1,Key2 . . .(Key3, . . .) )
Table2 (Key1, Key2 . . .)
Table3 (Key1, Key2, Key3, . . .)
  • Première forme normale (1NF)
  • Table1(Key1, aaa . . .)
  • Table2(Key1, Key2, bbb . .)
  • Table3(Key1, Key2, Key3, ccc. . .)

47
Problèmes de la 1NF
TransID RentDate CustID Phone LastName FirstName A
ddress City State ZipCode 1 4/18/02 3 502-777-757
5 Washington Elroy 95 Easy Street Smith's
Grove KY 42171 2 4/30/02 7 615-888-4474 Lasater Le
s 67 S. Ray Drive Portland TN 37148 3 4/18/02 8 61
5-452-1162 Jones Charlie 867 Lakeside
Drive Castalian Springs TN 37031 4 4/18/02 3 502-7
77-7575 Washington Elroy 95 Easy Street Smith's
Grove KY 42171
  • 1NF division en groupe
  • Encore des problèmes
  • Redondance
  • Dépendance fct cachée
  • Si un vidéo na pas été loué, quel est son titre?

TransID VideoID Copy Title Rent 1 1 2 2001 A
Space Odyssey 1.50 1 6 3 Clockwork
Orange 1.50 2 8 1 Hopscotch 1.50 2 2 1 Apocalyps
e Now 2.00 2 6 1 Clockwork Orange 1.50 3 9 1 Lug
gage Of The Gods 2.50 3 15 1 Fabulous Baker
Boys 2.00 3 4 1 Boy And His Dog 2.50 4 3 1 Blues
Brothers 2.00 4 8 1 Hopscotch 1.50 4 13 1 Surf
Nazis Must Die 2.50 4 17 1 Witches of
Eastwick 2.00
48
Définition de la 2ième forme normale
Dépend sur TransID ET VideoID
RentalLine(TransID, VideoID, Copy, Title, Rent)
  • Chaque champ non clé doit être fonctionnellement
    dépendant de la clé entière.
  • Sapplique que sur les clés à plusieurs champs
  • Diviser et créer une nouvelle table avec ces
    champs.

Dépend seulement sur VideoID
  • Dépendance fonctionnelle (définition)
  • Si, pour une certaine valeur de clé X, on peut
    toujours déterminer la valeur du champ Y alors le
    champ Y est dit fonctionnellement dépendant de X.

49
Exemple 2NF
RentalLine(TransID, VideoID, Copy, Title, Rent)
VideosRented(TransID, VideoID, Copy)
Videos(VideoID, Title, Rent)
  • Tître dépend seulement du VideoID
  • Chaque VideoID ne peut avoir quun seul tître
  • Le champ Rent est dépendant de VideoID
  • Rêgle dentreprise.
  • Pourrait être différent dans un autre club vidéo.
  • Certain club vidéo pourrait charger un loyé
    différent dépendant de la journée.
  • Chaque champ non clé est fonctionnellement
    dépendant de la clé et entièrement de la clé.

50
Exemple 2NF (Données)
VideosRented(TransID, VideoID, Copy)
TransID VideoID Copy 1 1 2 1 6 3 2 2 1 2 6 1 2 8
1 3 4 1 3 9 1 3 15 1 4 3 1 4 8 1 4 13 1 4 17 1
Videos(VideoID, Title, Rent)
VideoID Title Rent 1 2001 A Space
Odyssey 1.50 2 Apocalypse Now 2.00 3 Blues
Brothers 2.00 4 Boy And His Dog 2.50 5 Brother
From Another Planet 2.00 6 Clockwork
Orange 1.50 7 Gods Must Be Crazy 2.00 8 Hopscotc
h 1.50
(non modifié)
RentalForm2(TransID, RentDate, CustomerID,
Phone, Name, Address, City, State, ZipCode)
51
Exemple 2NF Problèmes
RentalForm2(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode)
TransID RentDate CustID Phone LastName FirstName A
ddress City State ZipCode 1 4/18/02 3 502-777-757
5 Washington Elroy 95 Easy Street Smith's
Grove KY 42171 2 4/30/02 7 615-888-4474 Lasater Le
s 67 S. Ray Drive Portland TN 37148 3 4/18/02 8 61
5-452-1162 Jones Charlie 867 Lakeside
Drive Castalian Springs TN 37031 4 4/18/02 3 502-7
77-7575 Washington Elroy 95 Easy Street Smith's
Grove KY 42171
  • Même en 2NF, certain problèmes persistent
  • Redondance
  • Dépendance fonctionnelle cachée
  • Si un client nouveau client na pas encore loué
    de vidéo, où mémorise-t-on ces données
    personnelles ?
  • Solution divisé.

52
Définition de la 3ième forme normale
Dépend du TransID
RentalForm2(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode)
Dépend seulement du CustomerID
  • Chaque champ non-clé doit être fct dépendant de
    la clé et seulement de la clé.
  • Solution divisé.
  • Exemple Les noms de client ne change pas à
    chaque transaction.

53
Exemple 3NF
RentalForm2(TransID, RentDate, CustomerID, Phone,
Name, Address, City, State, ZipCode)
Rentals(TransID, RentDate, CustomerID )
Customers(CustomerID, Phone, Name, Address, City,
State, ZipCode )
  • Les attributs du client ne dépendent que du
    numéro de client (CustomerID)
  • Solution diviser et créer une nouvelle table
    (Customer)
  • En laissant le CustomerID dans la table
    principale.
  • La 3NF est souvent plus facile à voir si les
    objets principaux ont déjà été identifiés

54
Exemple 3NF Données
Rentals(TransID, RentDate, CustomerID )
TransID RentDate CustomerID 1 4/18/02
3 2 4/30/02 7 3 4/18/02 8 4 4/18/02 3
Customers(CustomerID, Phone, Name, Address, City,
State, ZipCode )
CustomerID Phone LastName FirstName Address City S
tate ZipCode 1 502-666-7777 Johnson Martha 125
Main Street Alvaton KY 42122 2 502-888-6464 Smith
Jack 873 Elm Street Bowling Green KY 42101 3 502-7
77-7575 Washington Elroy 95 Easy Street Smith's
Grove KY 42171 4 502-333-9494 Adams Samuel 746
Brown Drive Alvaton KY 42122 5 502-474-4746 Rabitz
Victor 645 White Avenue Bowling
Green KY 42102 6 615-373-4746 Steinmetz Susan 15
Speedway Drive Portland TN 37148 7 615-888-4474 La
sater Les 67 S. Ray Drive Portland TN 37148 8 615-
452-1162 Jones Charlie 867 Lakeside
Drive Castalian Springs TN 37031 9 502-222-4351 Ch
avez Juan 673 Industry Blvd. Caneyville KY 42721 1
0 502-444-2512 Rojo Maria 88 Main Street Cave
City KY 42127
(non modifié)
VideosRented(TransID, VideoID, Copy)
Videos(VideoID, Title, Rent)
55
Tables en 3NF
Rentals(TransID, RentDate, CustomerID )
Customers(CustomerID, Phone, Name, Address, City,
State, ZipCode )
VideosRented(TransID, VideoID, Copy)
Videos(VideoID, Title, Rent)
56
Procédure pour obtenir la 3NF
  • Diviser les sections de données répétées
  • Avec les clés parentales appropriées pour que
    linformation mémorisé puisse être recombiné.
  • Vérifier les clés
  • Est-ce que chaque ligne est uniquement identifiée
    par la clé primaire ?
  • Est-ce que les relations MN sont bient
    décomposées ?
  • Vérifier que chaque colonne non-clé ne dépend que
    de la clé, quentièrement de la clé et que
    seulement de la clé.
  • Pas de dépendances fonctionnelles cachées.

57
Définition de la 4NF
EmployeeTasks(E, Specialty, Task)
  • Techniquement, si toutes les colonnes sont clé
    alors la devrait être en 3FN.
  • Dans certain cas il y a des dépendances
    fonctionnelles cachées entre les colonnes clés.
  • Exemple
  • EmployeeTasks(E, Specialty, Task)
  • Est en 3FN (BCNF) maintenant.
  • Rêgle d'entreprise - "Business Rules"
  • Chaque employé a plusieurs spécialités.
  • Chaque spécialité a plusieurs tâche - "task".
  • Les tâches dépendent toujours des spécialités.
  • Encore une fois, dans monde réel, la duplication
    serait probablement acceptée.

EmployeeSpecialty(E, Specialty)
Specialty(Specialty, Task)
EmployeeTasks(E, Specialty, Task)
Specialty(Specialty, Task)
acceptable
58
Boyce-Codd Normal Form (BCNF)
  • Dépendances fcts cachées
  • Exemple
  • Employee-Specialty(E, Specialty, Manager)
  • Est en 3FN.
  • Rêgle dentreprise Business rules.
  • Un employé peut avoir plusieurs spécialités.
  • Chaque spécialité a plusieurs managers.
  • Chaque managera seulement une spécialité.
  • Un employé a seulement 1 manager pour chaque
    spécialité.
  • Le problème est dans la dépendance fonctionnelle
    caché entre manager et spécialité.
  • Besoin dune table séparée pour manager.
  • But then we dont need to repeat specialty.
  • Dans monde réel, la duplication serait
    probablement acceptée (spécialité dans les 2
    tables.

Employee-Specialty(E, Specialty, Manager)
Employee(E, Manager)
Manager(Manager, Specialty)
Employee(E, Specialty, Manager)
Manager(Manager, Specialty)
acceptable
Write a Comment
User Comments (0)
About PowerShow.com