Η παρουσίαση φορτώνεται. Παρακαλείστε να περιμένετε

Η παρουσίαση φορτώνεται. Παρακαλείστε να περιμένετε

Σχεσιακή Άλγεβρα.

Παρόμοιες παρουσιάσεις


Παρουσίαση με θέμα: "Σχεσιακή Άλγεβρα."— Μεταγράφημα παρουσίασης:

1 Σχεσιακή Άλγεβρα

2 Εισαγωγή Στα προηγούμενα μαθήματα:
Εννοιολογικός Σχεδιασμός Βάσεων Δεδομένων (με χρήση του Μοντέλου Οντοτήτων/Συσχετίσεων) Λογικός Σχεδιασμός Βάσεων Δεδομένων (με χρήση του Σχεσιακού Μοντέλου)

3 Εισαγωγή Μετά τη φάση του σχεδιασμού, καταλήγουμε σε ένα σχεσιακό σχήμα. Δυο ερωτήματα Είναι ο σχεδιασμός μας καλός; Θεωρία Κανονικών Μορφών Πως θα υλοποιήσουμε (προγραμματίσουμε) την εφαρμογή μας χρησιμοποιώντας ένα ΣΔΒΔ; Σχεσιακή Άλγεβρα – SQL Θα αρχίσουμε από το ερώτημα 2 – για να δούμε γρήγορα πως η θεωρία βρήκε εφαρμογή σε πραγματικά συστήματα.

4 Σχεσιακή Άλγεβρα By relieving the brain of all unnecessary work, a good notation sets it free to concentrate on more advanced problems, and, in effect, increases the mental power of the race. -- Alfred North Whitehead ( ) p

5 Ορισμοί και Τροποποιήσεις
Προγράμματα που απαντούν σε επερωτήσεις για τον παρόν στιγμιότυπο της βάσης δεδομένων (querying) Το σχεσιακό μοντέλο έχει ένα σύνολο από πράξεις -> Σχεσιακή Άλγεβρα ΣΗΜΕΙΩΣΗ: Πέρα από τη σχεσιακή άλγεβρα και τη διατύπωση ερωτήσεων: - ορισμό του σχήματος - τροποποίηση του στιγμιότυπου (εισαγωγή, διαγραφή και τροποποίηση πλειάδων)

6 Σχεσιακή Άλγεβρα Γλώσσες Ερωτήσεων (Query Languages): Επιτρέπουν τον χειρισμό και την εύρεση πληροφορίας από μια βάση δεδομένων Το σχεσιακό μοντέλο υποστηρίζει απλές και ισχυρές γλώσσες ερωτήσεων (σε αντίθεση με το μοντέλο Ο/Σ)

7 Γλώσσες Ερωτήσεων != Γλώσσες Προγραμματισμού!
Σχεσιακή Άλγεβρα Γλώσσες Ερωτήσεων != Γλώσσες Προγραμματισμού! Δεν αναμένεται να είναι “Turing complete”. Δεν αναμένεται να χρησιμοποιηθούν για ”δύσκολους υπολογισμούς”. Υποστηρίζουν εύκολη και αποδοτική προσπέλαση σε μεγάλα σύνολα δεδομένων.

8 Σχεσιακή Άλγεβρα Δύο μαθηματικές γλώσσες ερωτήσεων αποτελούν τη βάση για τις πραγματικές γλώσσες ερωτήσεων (π.χ., SQL) και για την υλοποίησή τους Σχεσιακή Άλγεβρα: Λειτουργική “operational” (database byte-code!): αποτελείται από ένα σύνολο τελεστών και περιγράφει τα βήματα για τον υπολογισμό του αποτελέσματοσ Σχεσιακός Λογισμός (calculus): Επιτρέπει στους χρήστες να περιγράψουν τι θέλουν αλλά όχι πώς να το υπολογίσουν Αυτές οι τυπικές γλώσσες επηρέασαν τις εμπορικές γλώσσες (SQL, QBE) που θα δούμε στα επόμενα μαθήματα

9 Σχεσιακή Άλγεβρα Σχεσιακή άλγεβρα: έναν απλό τρόπο δημιουργίας νέων σχέσεων από υπάρχουσες. Ένα σύνολο από πράξεις που όταν εφαρμοστούν σε σχέσεις μας δίνουν νέες σχέσεις Μια ερώτηση εφαρμόζεται σε ένα στιγμιότυπο σχέσης και το αποτέλεσμα της ερώτησης είναι πάλι ένα στιγμιότυπο σχέσης

10 Οι πράξεις τις σχεσιακής άλγεβρας:
Σχεσιακή Άλγεβρα Οι πράξεις τις σχεσιακής άλγεβρας: 1. Πράξεις που αφαιρούν κομμάτια από μια σχέση είτε επιλέγοντας γραμμές είτε προβάλλοντας στήλες 2. Οι συνηθισμένες πράξεις συνόλου - ένωση, τομή, διαφορά 3. Πράξεις που συνδυάζουν πλειάδες από δύο σχέσεις 4. Μετονομασία γνωρισμάτων

11 Η πράξη της επιλογής (select)
Η Πράξη της Επιλογής Η πράξη της επιλογής (select) Επιλογή ενός υποσυνόλου των πλειάδων μιας σχέσης που ικανοποιεί μια συνθήκη επιλογής σ<συνθήκη επιλογής> (<όνομα σχέσης>)

12 σ<συνθήκη επιλογής> (<όνομα σχέσης>)
Η Πράξη της Επιλογής Επιλογή ενός υποσυνόλου των πλειάδων μιας σχέσης που ικανοποιεί μια συνθήκη επιλογής σ<συνθήκη επιλογής> (<όνομα σχέσης>) <όνομα γνωρίσματος> <τελεστής σύγκρισης> <όνομα γνωρίσματος> ή <σταθερή τιμή από το πεδίο ορισμού του γνωρίσματος> προτάσεις της μορφής συνθήκη =, >, <, ,  ,  συνδυασμένες με AND, OR, NOT

13 Παράδειγμα Ταινία Τίτλος Έτος Διάρκεια Είδος Παίζει Όνομα-Ηθοποιού Τίτλος Έτος Ηθοποιός Όνομα Διεύθυνση Έτος-Γέννησης Σύζυγος-Ηθοποιού

14 σ διάρκεια > 100 (Ταινία)
Η Πράξη της Επιλογής Παραδείγματα τίτλος χρόνος διάρκεια είδος Star Wars έγχρωμη Mighty Ducks έγχρωμη Wayne’s World έγχρωμη 1. Ταινίες με διάρκεια μεγαλύτερη των 100 λεπτών) σ διάρκεια > 100 (Ταινία) τίτλος χρόνος διάρκεια είδος Star Wars έγχρωμη Mighty Ducks έγχρωμη

15 σ διάρκεια > 100 AND χρόνος > 1995 (Ταινία)
Η Πράξη της Επιλογής τίτλος χρόνος διάρκεια είδος Star Wars έγχρωμη Mighty Ducks έγχρωμη Wayne’s World έγχρωμη 2. Ταινίες με διάρκεια μεγαλύτερη των 100 λεπτών που γυρίστηκαν μετά το 1995 σ διάρκεια > 100 AND χρόνος > 1995 (Ταινία) τίτλος χρόνος διάρκεια είδος Star Wars έγχρωμη

16 Η συνθήκη επιλογής εφαρμόζεται ανεξάρτητα σε κάθε πλειάδα
Η Πράξη της Επιλογής Η συνθήκη επιλογής εφαρμόζεται ανεξάρτητα σε κάθε πλειάδα Ο τελεστής είναι μοναδιαίος Ο βαθμός της σχέσης που προκύπτει ίδιος με τον βαθμό της αρχικής R Πλήθος πλειάδων μικρότερο ή ίσο με την αρχική σχέση: ποσοστό που επιλέγονται - επιλεκτικότητα (selectivity)

17 Ιδιότητες Η Πράξη της Επιλογής αντιμεταθετική
σ <συνθ1> (σ<συνθ2> (R)) = σ<συνθ2> (σ<συνθ1> (R)) σ <συνθ1> (σ<συνθ2> ( … σ<συνθn> (R) ..)) = σ <συνθ1> AND <συνθ2> ... AND <συνθn> (R)

18 Η πράξη της προβολής (project)
Η Πράξη της Προβολής Η πράξη της προβολής (project) Επιλογή συγκεκριμένων στηλών (γνωρισμάτων) π<λίστα γνωρισμάτων> (<όνομα σχέσης>)

19 τίτλος χρόνος διάρκεια είδος
Η Πράξη της Προβολής Παραδείγματα τίτλος χρόνος διάρκεια είδος Star Wars έγχρωμη Mighty Ducks έγχρωμη Wayne’s World έγχρωμη

20 π τίτλος, χρόνος, διάρκεια (Ταινία)
Η Πράξη της Προβολής 1. Τίτλος, χρόνος, διάρκεια των ταινιών π τίτλος, χρόνος, διάρκεια (Ταινία) τίτλος χρόνος διάρκεια Star Wars Mighty Ducks Wayne’s World

21 Προσοχή: απαλοιφή διπλότιμων
Η Πράξη της Προβολής 2. Είδος ταινιών π είδος (Ταινία) είδος έγχρωμη Προσοχή: απαλοιφή διπλότιμων

22 Τα γνωρίσματα έχουν την ίδια διάταξη
Η Πράξη της Προβολής Τα γνωρίσματα έχουν την ίδια διάταξη Ο τελεστής είναι μοναδιαίος Ο βαθμός της σχέσης είναι ίσος με τον αριθμό γνωρισμάτων στη <λίστα γνωρισμάτων> Πλήθος πλειάδων μικρότερο ή ίσο (πότε;) με την αρχική σχέση

23 Ιδιότητες αντιμεταθετική; π <λίστα1> (π <λίστα2> (R)) = ?
Η Πράξη της Προβολής Ιδιότητες αντιμεταθετική; π <λίστα1> (π <λίστα2> (R)) = ?

24 π διάρκεια (σ διάρκεια > 100 (Ταινία))
Σχεσιακή Άλγεβρα Παράδειγμα Διάρκειες μεγαλύτερες των 100 λεπτών π διάρκεια (σ διάρκεια > 100 (Ταινία)) διάρκεια 124 104

25 Πράξεις συνόλου Ένωση () Τομή () Διαφορά (-) Πράξεις Συνόλου
Συμβατότητα ως προς την ένωση Δύo σχέσεις R(A1, A2, …, An) και S(B1, B2, …, Bn) είναι συμβατές ως προς την ένωση όταν 1. Έχουν τον ίδιο βαθμό n 2.  i, dom(Ai) = dom(Bi)

26 Πράξεις Συνόλου Σύμβαση: η προκύπτουσα σχέση έχει τα ίδια ονόματα γνωρισμάτων με την πρώτη σχέση Απαλοιφή διπλότιμων

27   Σχεσιακή Άλγεβρα Οι πράξεις τις σχεσιακής άλγεβρας:
1. Πράξεις που αφαιρούν κομμάτια από μια σχέση είτε επιλέγοντας γραμμές είτε προβάλλοντας στήλες 2. Οι συνηθισμένες πράξεις συνόλου - ένωση, τομή, διαφορά 3. Πράξεις που συνδυάζουν πλειάδες από δύο σχέσεις 4. Μετονομασία γνωρισμάτων

28 σ Α > Β (R) Σχεσιακή Άλγεβρα Παράδειγμα Α Β 1 2 1 4 2 1 6 5 R
Α Β σ Α > Β (R) R Π Α (R) R  S R  S R - S S - R B C S

29 Μετονομασία όνομα στην ενδιάμεση σχέση R  Μετονομασία Παράδειγμα
ΜΕΓΑΛΗΣ_ΔΙΑΡΚΕΙΑΣ  σ διάρκεια > 100 (Ταινία)

30 R(λίστα-με-νέα-ονόματα) 
Μετονομασία μετονομασία γνωρισμάτων R(λίστα-με-νέα-ονόματα)  Παράδειγμα ΜΕΓΑΛΗΣ_ΔΙΑΡΚΕΙΑΣ (όνομα ταινίας, έτος παραγωγής, διάρκεια, είδος)  σ διάρκεια > 100 (Ταινία) όνομα ταινίας έτος παραγωγής διάρκεια είδος Star Wars έγχρωμη Mighty Ducks έγχρωμη

31 Καρτεσιανό Γινόμενο Καρτεσιανό Γινόμενο (ή χιαστί γινόμενο (cross product) ή χιαστί συνένωση (cross join)) R(A1, A2, …, An) x S(B1, B2, …, Bm) αποτέλεσμα η σχέση Q: Q(A1, A2, …, An, B1, B2, …, Bm) n + m γνωρίσματα nR * nS πλειάδες

32 Καρτεσιανό Γινόμενο R x S A R.B S.B C D R S Α Β B C D

33 Παράδειγμα Ταινία Τίτλος Έτος Διάρκεια Είδος Παίζει Όνομα-Ηθοποιού Τίτλος Έτος Ηθοποιός Όνομα Διεύθυνση Έτος-Γέννησης Σύζυγος-Ηθοποιού

34 Καρτεσιανό Γινόμενο Παράδειγμα Για κάθε ηθοποιό το όνομα και τον τίτλο-έτος για όλες τις έγχρωμες ταινίες στις οποίες παίζει π όνομα, τίτλος, έτος (σ είδος = “έγχρωμη” AND Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος = Ταινία.έτος (Παίζει x Ταινία)) ή π όνομα, τίτλος, έτος (σ Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος =Ταινία.έτος(Παίζει x (σ είδος = “έγχρωμη” (Ταινία)))

35 Καρτεσιανό Γινόμενο Ταινία Παίζει Τίτλος Έτος Διάρκεια Είδος
Τίτλος Έτος Διάρκεια Είδος Παραμύθι Έγχρωμη Παραμύθι Ασπρόμαυρη Φυγή Ασπρόμαυρη Άνοιξη Έγχρωμη Ταινία Όνομα-Ηθοποιού Τίτλος Έτος Αλίκη Παππά Παραμύθι 1930 Μαρία Γεωργίου Παραμύθι 1990 Κώστας Χρήστου Φυγή 2000 Μαρία Στεργίου Άνοιξη 1998 Παίζει

36 Συνένωση (ή θήτα συνένωση) (join)
συνδυασμός σχετιζόμενων πλειάδων R <συνθήκη συνένωσης> S (  σ <συνθήκη συνένωσης> (R x S) ) Συνθήκη συνένωσης Προτάσεις της μορφής =, >, <, ,  ,  Ai <τελεστής σύγκρισης> Bj όπου Ai γνώρισμα της R, Bj γνώρισμα της S, και dom(Ai) = dom(Bj) συνδυασμένες με AND

37 το αποτέλεσμα είναι οι συνδυασμοί πλειάδων που ικανοποιούν τη συνθήκη
Συνένωση το αποτέλεσμα είναι οι συνδυασμοί πλειάδων που ικανοποιούν τη συνθήκη η συνθήκη αποτιμάται για κάθε συνδυασμό αποτέλεσμα σχέση Q με n + m γνωρίσματα πλειάδες με τιμή null σε γνώρισμα συνένωσης δεν εμφανίζονται στο αποτέλεσμα

38 Συνένωση U A < D V U V A U.B U.C V.B V.C D Α Β C B C D U A<D AND U.B  V.B V

39 Συνένωση Παράδειγμα Για κάθε ηθοποιό το όνομα και τον τίτλο-έτος για όλες τις έγχρωμες ταινίες στις οποίες παίζει π όνομα, τίτλος, έτος (σ Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος =Ταινία.έτος(Παίζει x (σ είδος = “έγχρωμη” (Ταινία))) π όνομα, τίτλος, έτος (Παίζει Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος =Ταινία.έτος(σ είδος = “έγχρωμη” (Ταινία))

40 Συνένωση Ισότητας (equijoin)
όταν χρησιμοποιείται μόνο τελεστής ισότητας Συνθήκη συνένωσης Προτάσεις της μορφής Ai = Bj όπου Ai γνώρισμα της R, Bj γνώρισμα της S, και dom(Ai) = dom(Bj) συνδυασμένες με AND

41 Συνένωση Ισότητας R S Α Β 1 2 3 4 B C D 2 5 6 4 7 8 9 10 11
Α Β B C D A R.B S.B C D R S R.B = S.B

42 Φυσική Συνένωση Φυσική Συνένωση
συνένωση ισότητας όπου παραλείπουμε το γνώρισμα της δεύτερης σχέσης από το αποτέλεσμα όταν διαφορετικό όνομα - μετονομασία R * (λίστα1, λίστα2) S επιλεκτικότητα συνένωσης : μέγεθος αποτελέσματος / (nr * ns)

43 Φυσική Συνένωση R S R * S Α Β B C D A B C D

44 Φυσική Συνένωση U * V U V A B C D Α Β C B C D

45 Φυσική Συνένωση Παράδειγμα Για κάθε ηθοποιό το όνομα και τον τίτλο-έτος για όλες τις έγχρωμες ταινίες στις οποίες παίζει π όνομα, τίτλος, έτος (σ Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος =Ταινία.έτος(Παίζει x (σ είδος = “έγχρωμη” (Ταινία))) π όνομα, τίτλος, έτος (Παίζει Παίζει.τίτλος = Ταινία.τίτλος AND Παίζει.έτος =Ταινία.έτος(σ είδος = “έγχρωμη” (Ταινία)) π όνομα, τίτλος, έτος (Παίζει * (σ είδος = “έγχρωμη” (Ταινία))) είναι η τρίτη έκφραση ισοδύναμη των άλλων δύο;

46 Σχεσιακή Άλγεβρα Α Β Παράδειγμα R B C R x S R R.a >= S.b S S R R.a = S.b S R * S

47 Παρατήρηση ΠΡΟΣΟΧΗ Λύση του Ερωτήματος 3 των Ασκήσεων του Εργαστηρίου στη web σελίδα του μαθήματος

48 Σχεσιακή Άλγεβρα (ανακεφαλαίωση)
Γλώσσες Ερωτήσεων (Query Languages): Επιτρέπουν τον χειρισμό και την εύρεση πληροφορίας από μια βάση δεδομένων Το σχεσιακό μοντέλο υποστηρίζει απλές και ισχυρές γλώσσες ερωτήσεων Σχεσιακή άλγεβρα: έναν απλό τρόπο δημιουργίας νέων σχέσεων από παλιές (byte – code, assemply) Ένα σύνολο από πράξεις που όταν εφαρμοστούν σε σχέσεις μας δίνουν νέες σχέσεις

49 Το σχήμα της σχέσης εισόδου είναι ορισμένο
Σχεσιακή Άλγεβρα Μια ερώτηση εφαρμόζεται σε ένα στιγμιότυπο σχέσης και το αποτέλεσμα της ερώτησης είναι πάλι ένα στιγμιότυπο σχέσης Το σχήμα της σχέσης εισόδου είναι ορισμένο Το σχήμα του αποτελέσματος είναι επίσης ορισμένο

50 Οι πράξεις τις σχεσιακής άλγεβρας:
Σχεσιακή Άλγεβρα Οι πράξεις τις σχεσιακής άλγεβρας: 1. Πράξεις που αφαιρούν κομμάτια από μια σχέση είτε επιλέγοντας γραμμές (σ) είτε προβάλλοντας στήλες (π) 2. Οι συνηθισμένες πράξεις συνόλου: ένωση, τομή, διαφορά 3. Πράξεις που συνδυάζουν πλειάδες από δύο σχέσεις 4. Μετονομασία γνωρισμάτων

51 Πλήρες σύνολο πράξεων Επίσης τομή () συνένωση επιλογή (σ)
Σχεσιακή Άλγεβρα Πλήρες σύνολο πράξεων Επίσης τομή () συνένωση συνένωση ισότητας φυσική συνένωση (*) επιλογή (σ) προβολή (π) ένωση () διαφορά (-) καρτεσιανό γινόμενο (x)

52 Παράδειγμα Ταινία Τίτλος Έτος Διάρκεια Είδος Παίζει Όνομα-Ηθοποιού Τίτλος Έτος Ηθοποιός Όνομα Διεύθυνση Έτος-Γέννησης Σύζυγος-Ηθοποιού

53 Παράδειγμα Παράδειγμα Όλες τις ταινίες (τίτλο, έτος) με ηθοποιό τη Βουγιουκλάκη Όλες τις ταινίες (τίτλο, έτος) μεταξύ 1956 και 1975 με ηθοποιό τη Βουγιουκλάκη

54 Παράδειγμα Παράδειγμα Για κάθε ηθοποιό το όνομα του και τον τίτλο-έτος για όλες τις (έγχρωμες) ταινίες στις οποίες παίζει μαζί με τον σύζυγο του/της Ονόματα ηθοποιών που δεν έπαιξαν σε καμία ταινία μεταξύ 1995 και 2000

55 R (Παίζει): Όλοι η ηθοποιοί και οι ταινίες που παίζουν
Διαίρεση Διαίρεση R S Χρήσιμη όταν για κάθε, παράδειγμα: βρες τον ηθοποιό που παίζει σε όλες (σε κάθε) ταινία που παίζει και η Sharon Stone. R (Παίζει): Όλοι η ηθοποιοί και οι ταινίες που παίζουν S: Όλες τις ταινίες που παίζει η Sharon Stone Q: Οι ηθοποιοί που (το όνομα τους) εμφανίζονται στη σχέση Παίζει (R) με υπόλοιπα γνωρίσματα να παίρνουν όλες τις τιμές του S

56 Διαίρεση Διαίρεση R S; Παράδειγμα S R A B C a1 b1 c1 a1 b1 c2 A

57 Διαίρεση Διαίρεση R S; S Παράδειγμα R A B C a1 b1 c1 A B a1 b1 c2

58 Διαίρεση A B a1 b1 a1 b3 a1 b4 a2 b2 a2 b4 a3 b2 R R S S Ζ = {Α, Β} Χ = {B} B b2 b4 R(Z) S(X), X  Z Q(Υ)? Q Υ = Ζ - Χ Υ = {A} A a2 t  Q,  tR1  R, tR1[Y] = t  tS  S,  tR R, tR[X] = tS και tR[Y] = t

59 Διαίρεση R(Z) S(X), X  Z Το αποτέλεσμα είναι μια καινούργια σχέση Q(Y) όπου Y = Z - X και t  Q(Y) ανν  tR1 R, tR1[Y] = t και  tS  S,  tR R, tR[X] = tS, και tR[Y] = t αναλογία με τη διαίρεση ακεραίων διαίρεση ακεραίων: R / S το αποτέλεσμα Q τέτοιο ώστε: Q * S  R διαίρεση σχέσεων: R S το αποτέλεσμα Q τέτοιο ώστε ...

60 Παράδειγμα Ταινία Τίτλος Έτος Διάρκεια Είδος Παίζει Όνομα-Ηθοποιού Τίτλος Έτος Ηθοποιός Όνομα Διεύθυνση Έτος-Γέννησης Σύζυγος-Ηθοποιού

61 Χωρίς να χρησιμοποιήσω την πράξη της διαίρεσης;
Διαίρεση παράδειγμα: βρες τον ηθοποιό που παίζει σε όλες (σε κάθε) ταινία που παίζει και η Sharon Stone. S: Όλες τις ταινίες που παίζει η Sharon Stone Q: Οι ηθοποιοί που (το όνομα τους) εμφανίζονται στη σχέση Παίζει (R) με υπόλοιπα γνωρίσματα να παίρνουν όλες τις τιμές του S S  π τίτλος, έτος (σ Όνομα Ηθοποιού = Sharon Stone (Παίζει)) Q  Παίζει S Χωρίς να χρησιμοποιήσω την πράξη της διαίρεσης;

62 Διαίρεση Iσοδύναμη έκφραση για το Q(Υ)  R(Ζ) S(Χ) Υπολογισμός των πλειάδων που δεν πρέπει να είναι στο αποτέλεσμα. Μια πλειάδα y αποκλείεται από το αποτέλεσμα αν όταν τις συνάψουμε μια τιμή x από το S, η πλειάδα <y, x> δεν ανήκει στο R Τ1  (S x π Y (R)) - R Q  π Y (R) - π Y (T1)

63 S  π τίτλος, έτος (σ Όνομα Ηθοποιού = Sharon Stone (Παίζει))
Διαίρεση Παράδειγμα (εφαρμογή ισοδύναμης έκφρασης): βρες τον ηθοποιό που παίζει σε όλες (σε κάθε) ταινία που παίζει και η Sharon Stone. Μια πλειάδα y αποκλείεται από το αποτέλεσμα αν όταν τις συνάψουμε μια τιμή x από το S, η πλειάδα <y, x> δεν ανήκει στο R Τ1  (S x π Y (R)) - R Q  π Y (R) - π Y (T1) S  π τίτλος, έτος (σ Όνομα Ηθοποιού = Sharon Stone (Παίζει)) Τ1  (S x π ηθοποιός (Παίζει)) – Παίζει (μένουν μόνο οι ηθοποιοί που δεν παίζουν σε κάποια ταινία που παίζει η Stone!) Q  π ηθοποιός (Παίζει) – π ηθοποιός (Τ1)

64 Συναθροιστικές Συναρτήσεις
Χρήσιμη η δυνατότητα της συνάθροισης: συνδυασμός των πλειάδων μιας σχέσης για τον υπολογισμό μιας συναθροιστικής τιμής Παραδείγματα: πόσοι ηθοποιοί παίζουν σε μια ταινία, ποιος ηθοποιός πήρε το μεγαλύτερο μισθό, κ.λ.π.

65 Συναθροιστικές Συναρτήσεις
συναρτήσεις που παίρνουν ως παράμετρο μια συλλογή (όχι σύνολο) από τιμές συνήθεις συναρτήσεις: SUM, AVERAGE, MAX, MIN, COUNT (πλήθος πλειάδων) αποτέλεσμα μια σχέση και όχι μια τιμή Ƒ <λίστα συναρτήσεων> (<όνομα σχέσης>) ζεύγη <συνάρτηση γνώρισμα>

66 Συναθροιστικές Συναρτήσεις
Παράδειγμα: μέση διάρκεια ταινιών AVERAGE_διάρκεια 91 Ƒ AVERAGE διάρκεια(Ταινία) Παράδειγμα: παλιότερη και πιο πρόσφατη έγχρωμη ταινία Ƒ ΜΙΝ έτος, ΜΑΧ έτος ( σ είδος = έγχρωμη (Ταινία)) ΜΙΝ_έτος MAX_έτος

67 Συναθροιστικές Συναρτήσεις
Παρατήρηση : σύμβαση για το όνομα των γνωρισμάτων του αποτελέσματος (δηλ, concatenation του ονόματος της συνάρτησης με το όνομα του γνωρίσματος)- δυνατή και η μετονομασία

68 Συναθροιστικές Συναρτήσεις
Ομαδοποίηση <γνωρίσματα ομαδοποίησης> Ƒ <λίστα συναρτήσεων> (<όνομα σχέσης>) Παράδειγμα: πόσοι ηθοποιοί ανά ταινία

69 Συναθροιστικές Συναρτήσεις
Παράδειγμα: αριθμός ηθοποιών ανά ταινία τίτλος, έτος Ƒ COUNT Όνομα-Ηθοποιού (Παίζει) Τίτλος Έτος COUNT_Όνομα Ηθοποιού Sixth Sense Run Lola Run Eyes Wide Shut Ποιο θα ήταν το αποτέλεσμα αν δεν υπήρχαν τα γνωρίσματα ομαδοποίησης;

70 Αναδρομική Κλειστότητα
Αρ_Ταυτ Διεύθυνση Μισθός Προϊστάμενος R Δεν είναι δυνατόν να βρούμε όλους τους υφισταμένους που επιτηρεί σε οποιοδήποτε επίπεδο ένας συγκεκριμένος προϊστάμενος (π.χ., Αρ_Ταυτ = Μ20200) Π1 (Προϊστ1)  π Αρ_Ταυτ (σ Προϊστάμενος = Μ20200 (R)) Π2(Προϊστ2)  π Αρ_Ταυτ ( Π Προϊστ1 = Προϊστάμενος (R))

71 Εξωτερική Συνένωση Εξωτερική Συνένωση
Όταν θέλουμε να κρατήσουμε στο αποτέλεσμα όλες τις πλειάδες - και αυτές που δεν ταιριάζουν) είτε της σχέσης στα αριστερά (αριστερή εξωτερική συνένωση) είτε της σχέσης στα δεξιά (δεξιά εξωτερική συνένωση) R * S R S Α C B null Α C B 3 null 9 Α C Α B Α C B

72 ΣΥΧΝΑΖΕΙ(ΠΟΤΗΣ, ΜΑΓΑΖΙ) ΣΕΡΒΙΡΕΙ(ΜΑΓΑΖΙ, ΜΠΥΡΑ)
Παράδειγμα ΠΡΟΤΙΜΑ(ΠΟΤΗΣ, ΜΠΥΡΑ) ΣΥΧΝΑΖΕΙ(ΠΟΤΗΣ, ΜΑΓΑΖΙ) ΣΕΡΒΙΡΕΙ(ΜΑΓΑΖΙ, ΜΠΥΡΑ) Μαγαζιά που σερβίρουν τουλάχιστον δύο διαφορετικές μπύρες Μαγαζιά που σερβίρουν ακριβώς δύο διαφορετικές μπύρες Τα μαγαζιά που σερβίρουν όλες τις μπύρες που προτιμούν οι πότες. Τα μαγαζιά που δεν σερβίρουν καμία μπύρα που προτιμά ο πότης «Χαράλαμπο» Τα μαγαζιά που δεν σερβίρουν καμία μπύρα που να αρέσει σε κάποιον πότη.

73 Ορισμοί Σχεσιακού Μοντέλου και
Τροποποιήσεις Σχέσεων

74 Ορισμοί και Τροποποιήσεις
γλώσσες ερωτήσεων που απαντούν σε ερωτήσεις για τον παρόν στιγμιότυπο της βάσης δεδομένων (quering) επεκτάσεις που δεν είναι μέρος του τυπικού σχεσιακού μοντέλου αλλά εμφανίζονται σε πραγματικές γλώσσες ερωτήσεων (π.χ., SQL) συναθροιστικές συναρτήσεις ορισμοί σχήματος/όψεων τροποποιήσεις στιγμιοτύπων (εισαγωγή, διαγραφή και τροποποίηση πλειάδων)

75 Ορισμός Σχήματος Ορισμός Σχήματος
Για κάθε σχεσιακό σχήμα μια γλώσσα ορισμού δεδομένων 1. Ορισμός σχήματος (όνομα στη σχεσιακή βάση δεδομένων) 2. Ορισμός των (σχημάτων) σχέσεων που αποτελούν τη βάση Όνομα σχέσης, ονόματα και πεδία ορισμού των γνωρισμάτων, περιορισμοί ορθότητας 3. Ορισμοί πεδίων ορισμού

76 Όψεις Όψεις Μια έκφραση σε σχεσιακή άλγεβρα παράγει μια σχέση ως αποτέλεσμα Μπορούμε να την θεωρήσουμε ως μια έκφραση που ορίζει μια σχέση. Η σχέση δεν παράγεται μέχρι η έκφραση να εκτελεστεί. (όψη) Αφού οριστεί μια όψη μπορεί να χρησιμοποιηθεί ως πραγματική σχέση

77 Όψεις Διαφορά από την σχέση που ορίζεται με ανάθεση: η ανάθεση υπολογίζεται μόνο μια φορά, το αποτέλεσμα δεν αλλάζει όταν αλλάζουν τα στιγμιότυπα των σχέσεων - η όψη υπολογίζεται εκ νέου Αποθηκεύουμε τον ορισμό Τροποποιήσεις μέσω όψεων Υλοποιημένη (materialized) όψη

78 Πράξεις Ενημέρωσης Πράξεις Ενημέρωσης
Η σχεσιακή άλγεβρα είναι μια γλώσσα ερωτήσεων Δυνατότητα τροποποίησης της βάσης δεδομένων: 1. Εισαγωγή πλειάδων 2. Διαγραφή πλειάδων 3. Τροποποίηση πλειάδων που ήδη υπάρχουν

79 Εισαγωγή Εισαγωγή Παρέχει μια λίστα από τιμές γνωρισμάτων για μια νέα πλειάδα που πρέπει να εισαχθεί στη σχέση Ποιους από τους περιορισμούς (πεδίου ορισμού, κλειδιού, ακεραιότητας οντοτήτων και αναφορικής ακεραιότητας) μπορεί να παραβιάζει μια τέτοια λίστα τιμών; Σε περίπτωση παραβίασης: Απόρριψη εισαγωγής ή προσπάθεια διόρθωσης της αιτίας (διάδοση προς τα πίσω, πότε;)

80 Διαγραφή Διαγραφή Προσδιορίζεται μια συνθήκη πάνω στα γνωρίσματα της σχέσης και διαγράφονται οι πλειάδες που την ικανοποιούν Ποιους από τους περιορισμούς (πεδίου ορισμού, κλειδιού, ακεραιότητας οντοτήτων και αναφορικής ακεραιότητας) μπορεί να παραβιάζει το αποτέλεσμα μια διαγραφής; Σε περίπτωση παραβίασης (αναφορικής ακεραιότητας): απόρριψη της διαγραφής διάδοση της διαγραφής τροποποίηση των τιμών των αναφορικών γνωρισμάτων

81 Τροποποίηση Τροποποίηση
Προσδιορίζεται μια συνθήκη πάνω στα γνωρίσματα της σχέσης και τροποποιούνται οι πλειάδες που την ικανοποιούν Ποιους από τους περιορισμούς (πεδίου ορισμού, κλειδιού, ακεραιότητας οντοτήτων και αναφορικής ακεραιότητας) μπορεί να παραβιάζει το αποτέλεσμα μιας τροποποίησης; Όταν το γνώρισμα που τροποποιείται είναι ξένο κλειδί ή κλειδί;


Κατέβασμα ppt "Σχεσιακή Άλγεβρα."

Παρόμοιες παρουσιάσεις


Διαφημίσεις Google