Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 2



Σχετικά έγγραφα
Η SQL ως γλώσσα ερωτημάτων. Υπενθυμίζουμε: Σχέση = Πίνακας Πλειάδα = Εγγραφή = Γραμμή (Πίνακα) Πεδίο = Γνώρισμα (Σχέσης) = Στήλη (Πίνακα)

Η Γλώσσα Βάσεων εδοµένων SQL

Η Γλώσσα SQL. What is the average salary in the Toy department? Anonymous SQL user

SQL. Πριν µια σύντοµη επανάληψη της σχεσιακής άλγεβρας. H SQL έχει διάφορα τµήµατα: Γλώσσα Χειρισµού εδοµένων (ΓΧ )

SQL. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Η Γλώσσα SQL. Βάσεις εδοµένων Ευαγγελία Πιτουρά 1

SQL. Πριν μια σύντομη επανάληψη της σχεσιακής άλγεβρας. H SQL έχει διάφορα τμήματα: Γλώσσα Ορισμού εδομένων (ΓΟ ) Γλώσσα Χειρισμού εδομένων (ΓΧ )

SQL. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Βάσεις Δεδομένων Ευαγγελία Πιτουρά 2. Πως θα υλοποιήσουμε (προγραμματίσουμε) την εφαρμογή μας χρησιμοποιώντας ένα σχεσιακό Σ Β :

Η γλώσσα SQL. Βάσεις Δεδομένων : SQL 1

Βάσεις Δεδομένων Ευαγγελία Πιτουρά 2. Πως θα υλοποιήσουμε (προγραμματίσουμε) την εφαρμογή μας χρησιμοποιώντας ένα σχεσιακό Σ Β :

Η γλώσσα SQL. Βάσεις Δεδομένων : SQL 1

Βάσεις δεδομένων. (7 ο μάθημα) Ηρακλής Βαρλάμης

SQL. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Η Γλώσσα SQL. SQL αποτελείται από: DDL (Data Definition Language) - ορισμός, δημιουργία, τροποποίηση και διαγραφή σχήματος.

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

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

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

ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ ΤΜΗΜΑ ΠΟΛΙΤΙΣΜΙΚΗΣ ΤΕΧΝΟΛΟΓΙΑΣ ΚΑΙ ΕΠΙΚΟΙΝΩΝΙΑΣ. Επιλέγει όλες τις πλειάδες, από μια σχέση R, που ικανοποιούν τη συνθήκη επιλογής.

Η SQL ως γλώσσα τροποποίησης Δεδομένων

ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΑΤΡΩΝ - ΤΜΗΥΠ ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι

Ορισμοί Σχεσιακού Μοντέλου και (απλές)τροποποιήσεις Σχέσεων στην SQL. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Τμήμα Πληροφορικής ΑΠΘ

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

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

Σχεσιακή Άλγεβρα. Βάσεις Δεδομένων : Σχεσιακή Άλγεβρα 1

Σχεσιακή Άλγεβρα. Εισαγωγή. Εισαγωγή. Εισαγωγή. Παράδειγμα. Εισαγωγή. Ταινία Τίτλος Έτος Διάρκεια Είδος. Παίζει Όνομα-Ηθοποιού Τίτλος Έτος.

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

Σχεσιακή Άλγεβρα. Προγράµµατα που απαντούν σε ερωτήσεις για τον παρόν στιγµιότυπο της βάσης δεδοµένων (quering)

Τελεστής Προβολής - Παράδειγμα. Π Πόλη, Εξάμηνο (Φοιτητές)

Σχεσιακός Λογισµός. Σχεσιακό Μοντέλο. Έννοιες Τυπικές Γλώσσες Ερωτήσεων Σχεσιακή Άλγεβρα Σχεσιακός Λογισµός Πλειάδων Σχεσιακός Λογισµός Πεδίου

Σχεσιακή Άλγεβρα. Προγράμματα που απαντούν σε επερωτήσεις για τον τρέχον στιγμιότυπο της βάσης δεδομένων (querying)

Βάσεις εδοµένων Ευαγγελία Πιτουρά 2. Εννοιολογικός Σχεδιασµός Βάσεων Δεδοµένων (µε χρήση του Μοντέλου Οντοτήτων/Συσχετίσεων)

Σχεσιακή Άλγεβρα. Προγράµµατα που απαντούν σε επερωτήσεις για τον παρόν στιγµιότυπο της βάσης δεδοµένων (querying)

SQL. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

(Μέρος 3:Γλώσσα Ορισµού, Γλώσσα Τροποποίησης, Ενσωµατωµένη SQL) Βάσεις εδοµένων Ευαγγελία Πιτουρά 2

Σχεσιακός Λογισµός. Σχεσιακός Λογισµός Πλειάδων. σχεσιακά πλήρης γλώσσα

SQL Data Manipulation Language

Σχεσιακή Άλγεβρα Σχεδιασμός Βάσεων Δεδομένων

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

Εισαγωγή. Σχεδιασµός µιας Β

Kεφ.2: Σχεσιακό Μοντέλο (επανάληψη) Κεφ.6.1: Σχεσιακή Άλγεβρα

Βάσεις Δεδομένων. Βασίλειος Βεσκούκης Εισαγωγή στη γλώσσα SQL (Structured Query Language) Η γλώσσα SQL

Query-by-Example (QBE)

Η SQL αποτελείται από δύο υποσύνολα, τη DDL και τη DML.

H SQL είναι η γλώσσα για όλα τα εμπορικά σχεσιακά συστήματα διαχείρισης βάσεων δεδομένων

Βάσεις δεδομένων. (6 ο μάθημα) Ηρακλής Βαρλάμης

Σχεσιακό Μοντέλο. Εισαγωγή. Βάσεις εδοµένων : Σχεσιακό Μοντέλο 1


Εισαγωγή. Γενική Εικόνα του Μαθήµατος. Το εσωτερικό ενός Σ Β. Εισαγωγή. Εισαγωγή Σ Β Σ Β. Αρχεία ευρετηρίου Κατάλογος συστήµατος Αρχεία δεδοµένων

Βάσεις Δεδομένων. Εργαστήριο ΙV. Τμήμα Πληροφορικής ΑΠΘ

Αρχεία και Βάσεις Δεδομένων

ΠΑΝΕΠΙΣΤΗΜΙΟ ΠΑΤΡΩΝ - ΤΜΗΥΠ ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι

Σχεδιασµός µιας Β. Ένας απλός τρόπος αναπαράστασης δεδοµένων: ένας διδιάστατος πίνακας που λέγεται σχέση Γνωρίσµατα

GROUP BY, HAVING, COUNT, MIN, MAX, SUM, AVG, ROLLUP.

Τμήμα Πληροφορικής ΑΠΘ

Εισαγωγή στην πληροφορική

Η Γλώσσα SQL. Μέρος α. Η Γλώσσα SQL Σελίδα 1

Βάσεις δεδομένων. (4 ο μάθημα) Ηρακλής Βαρλάμης

Certified Data Base Designer (CDBD)

Λογικός Σχεδιασµός Σχεσιακών Σχηµάτων: Αποσύνθεση. Βάσεις εδοµένων Ευαγγελία Πιτουρά 1

Σχεδιασµός Σχεσιακών Σχηµάτων

Το εσωτερικό ενός Σ Β

Ηλεκτρονικοί Υπολογιστές II

Σχεσιακός Λογισμός. Σχεσιακός Λογισμός Πλειάδων. σχεσιακά πλήρης γλώσσα

ΗΥ-360 Αρχεία και Βάσεις Δεδομένων Διδάσκων: Δ. Πλεξουσάκης. Φροντιστήριο SQL Examples ΙΙ Ξένου Ρουμπίνη

ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Τμήμα Διοίκησης Επιχειρήσεων (Γρεβενά) ΤΕΙ ΔυτικήςΜακεδονίας

Σχεδιασµός µιας Β. Εισαγωγή. Μετατροπή σε σχεσιακό -> είσοδο σε ένα Σ Β. Εισαγωγή. Ιδέες Ο/Σ Σχέσεις Σχεσιακό Σ Β

2 ο Σύνολο Ασκήσεων. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

1 / 97

Σχεδιασμός μιας εφαρμογής ΒΔ: Βήματα. 1. Συλλογή και Ανάλυση Απαιτήσεων(requirement analysis)

Βάσεις Δεδομένων. Τ.Ε.Ι. Ιονίων Νήσων Σχολή Διοίκησης και Οικονομίας - Λευκάδα

1 / 87

Σχεδιασμός Βάσεων Δεδομένων

Βάσεις Δεδομένων και Ευφυή Πληροφοριακά Συστήματα Επιχειρηματικότητας. 3ο Μάθημα: Εισαγωγή στην SQL. Δρ. Κωνσταντίνος Χ.

Κεφάλαιο 3. Ερωτήματα SQL

Σχεδιασμός μιας Β : Βήματα

Διάλεξη 13: Γλώσσα Επεξεργασίας Δεδομένων/ Data Manipulation Language (SQL DML) I. Διδάσκων: Παναγιώτης Ανδρέου

Επεξεργασία Ερωτήσεων

Το Σχεσιακό Μοντέλο. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

ΠΑΝΕΠΙΣΤΗΜΙΟ ΙΩΑΝΝΙΝΩΝ ΤΜΗΜΑ ΜΑΘΗΜΑΤΙΚΩΝ

Βάσεις Δεδομένων (Databases)

Βάσεις εδοµένων. Συνολοθεωρητικές Πράξεις. Ειδικές Πράξεις. Εκφράσεις. Θεµελίωση της Σχεσιακού Μοντέλου εδοµένων. Σχεσιακή Άλγεβρα Σχεσιακός Λογισµός

Λογικός Σχεδιασμός Σχεσιακών Σχημάτων: Αποσύνθεση

ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι. Ενότητα 5: SQL (Απλή SELECT) Ευαγγελίδης Γεώργιος. Τμήμα Εφαρμοσμένης Πληροφορικής ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι

Μοντέλο Οντοτήτων-Συσχετίσεων

Επεξεργασία Ερωτήσεων

ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι. Ενότητα 6: SQL (Συζεύξεις, Εμφώλευση, Ομαδοποίηση) Ευαγγελίδης Γεώργιος. Τμήμα Εφαρμοσμένης Πληροφορικής ΒΑΣΕΙΣ ΔΕΔΟΜΕΝΩΝ Ι

ΘΕΜΑΤΑ. Θέμα 1 ο Σύμφωνα με τους παραπάνω πίνακες και τη θέση που έχουν τα ξένα κλειδιά βρείτε τους

ΣΧΕΔΙΑΣΜΟΣ ΒΑΣΕΩΝ ΔΕΔΟΜΕΝΩΝ ΕΡΓΑΣΤΗΡΙΟ 3

ΣΧΕΣΙΑΚΟ ΜΟΝΤΕΛΟ Relational Model. SQL Μαθ. #11

Εισαγωγή. Σχεσιακό Μοντέλο. Τυπικές Γλώσσες Ερωτήσεων Σχεσιακή Άλγεβρα Σχεσιακός Λογισµός Πλειάδων Σχεσιακός Λογισµός Πεδίου

Μοντέλο Οντοτήτων-Συσχετίσεων

SQL: Αιτήματα. Κεφάλαιο 5. Database Management Systems, R. Ramakrishnan and J. Gehrke


Βάσεις Δεδομένων (Databases)

Τμήμα Πληροφορικής ΑΠΘ

Lecture 16: SQL DML III

Σχεσιακή Άλγεβρα. Βάσεις Δεδομένων Ευαγγελία Πιτουρά 1

Σχεσιακή Άλγεβρα και Σχεσιακός Λογισμός. Σχεσιακή Άλγεβρα Σχεσιακός Λογισμός

Transcript:

Η Γλώσσα SQL Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 1 Η γλώσσα SQL What men or gods are these? What maidens loth? What mad pursuit? What struggle to escape? What pipes and timbrels? What wild ectasy? John Keats, Ode on a Grecian Urn What is the average salary in the Toy department? Anonymous SQL user Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 2

Η Γλώσσα Βάσεων εδοµένων SQL (Μέρος 1: Βασική οµή, Πράξεις Συνόλου, Συναθροιστικές) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 3 Η γλώσσα SQL Η standard γλώσσα για σχεσιακές βάσεις δεδοµένων. αρχικά Sequel στην IBM ως µέρος του System R, τώρα SQL (Stuctured Query Language) SQL--89, SQL--92, SQL-99 Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 4

Η γλώσσα SQL Τυπικές (Formal) Γλώσσες σχεσιακή άλγεβρα σχεσιακός λογισµός (πλειάδων και πεδίου) Εµπορικές Γλώσσες Προγραµµατισµού SQL QBE Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 5 Η γλώσσα SQL H SQL έχει διάφορα τµήµατα: Γλώσσα Ορισµού εδοµένων (ΓΟ ) Γλώσσα Χειρισµού εδοµένων (ΓΧ ) Ενσωµατωµένη Γλώσσα Χειρισµού εδοµένων Ορισµό Όψεων Εξουσιοδότηση (authentication) Ακεραιότητα Έλεγχο Συναλλαγών Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 6

Η γλώσσα SQL SQL αποτελείται από: DDL (Data Definition Language) - ορισµός, δηµιουργία, τροποποίηση και διαγραφή σχήµατος. DML (Data Manipulation Language) - ορισµός, δηµιουργία, τροποποίηση, διαγραφή και επιλογή δεδοµένων (γλώσσα ερωτήσεων). Προδιαγραφές ασφάλειας - χρήστες και δικαιώµατα. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 7 Βασική οµή Μια χαρακτηριστική ερώτηση σε SQL έχει την εξής µορφή: ονόµατα γνωρισµάτων Βασική οµή select Α 1, Α 2,.., Α n from R 1, R 2, R m where P ονόµατα σχέσεων συνθήκη Ισοδύναµο του: π A 1, A2,.., An (σ P (R 1 x R 2 x R m )) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 8

Βασική οµή select Α1, Α2,.., Αn from R 1, R 2, R m where P π A1, A 2,.., A n (σ P (R 1 x R 2 x R m )) select αντιστοιχεί στην πράξη της προβολής της σχεσιακής άλγεβρας. Ποια γνωρίσµατα θέλουµε να υπάρχουν στο αποτέλεσµα της ερώτησης. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 9 Βασική οµή select Α 1, Α 2,.., Α n from R1, R2, Rm where P π A1, A 2,.., A n (σ P (R 1 x R 2 x R m )) from αντιστοιχεί στην πράξη του καρτεσιανού γινοµένου της σχεσιακής άλγεβρας. Ποιες σχέσεις θα χρησιµοποιηθούν για τον υπολογισµό του αποτελέσµατος. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 10

Βασική οµή select Α 1, Α 2,.., Α n from R1, R2, Rm where P π A1, A 2,.., A n (σ P (R 1 x R 2 x R m )) where αντιστοιχεί στη συνθήκη της πράξης της επιλογής στη σχεσιακή άλγεβρα. Το κατηγόρηµα P έχει γνωρίσµατα των σχέσεων που εµφανίζονται στο from. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 11 Βασική οµή Όταν δεν υπάρχει το where, το P θεωρείται ότι ισχύει. ΠΡΟΣΟΧΗ: ε γίνεται απαλοιφή των διπλών εµφανίσεων. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 12

Βασική οµή Ταινία Τίτλος Έτος ιάρκεια Είδος Παίζει Όνοµα Τίτλος Έτος Ηθοποιός Όνοµα ιεύθυνση Έτος-Γέννησης Σύζυγος-Ηθοποιού Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 13 Βασική οµή Παράδειγµα: Ονόµατα ηθοποιών που παίζουν στην ταινία Gone by the Wind select Όνοµα from Παίζει where Τίτλος = ''Gone by the Wind'' Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 14

Select Select Παράδειγµα: Ονόµατα όλων των ηθοποιών που έχουν παίξει σε ταινίες (ή σε ασπρόµαυρες ταινίες) select Όνοµα from Παίζει Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 15 Select Η SQL επιτρέπει πολλαπλές εµφανίσεις της ίδιας πλειάδας σε µια σχέση. Μια σχέση στην SQL είναι ένα πολυσύνολο (multiset) ή θύλακας (bag). Απαλοιφή διπλών εµφανίσεων select distinct Όνοµα from Παίζει Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 16

Select Επιλογή όλων των γνωρισµάτων select * from Παίζει Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 17 Select Αριθµητικές πράξεις (+, -, *, /) ανάµεσα σε σταθερές ή γνωρίσµατα πλειάδων select Τίτλος, Έτος, ιάρκεια / 60, Είδος from Ταινία Επιστρέφει µια σχέση ίδια µε τη σχέση Ταινία µόνο που το γνώρισµα διάρκεια µας δίνει τις ώρες (έχει διαιρεθεί µε το 60) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 18

Where Where Παράδειγµα: Τον τίτλο όλων των ταινιών που γυρίστηκαν µετά το 1995 και είναι ασπρόµαυρες select Τίτλος from Ταινία where Έτος > 1995 and Είδος = ''Ασπρόµαυρη'' Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 19 Where συνθήκη του where Λογικοί τελεστές: and, or, not Τελεστές σύγκρισης: <, <=, >, >=, =, <>, between, not between ανάµεσα σε αριθµητικές εκφράσεις,συµβολοσειρές (strings), και ειδικούς τύπους. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 20

Where Παράδειγµα χρήσης του between : select Τίτλος from Ταινία where Έτος between 1990 and 1995 αντί του select Τίτλος from Ταινία where Έτος >= 1990 and Έτος <= 1995 Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 21 Βασική οµή Όταν το ίδιο γνώρισµα εµφανίζεται στο σχήµα περισσότερων από µια σχέσεων, τότε διάκριση βάση του συµβολισµού: <όνοµα-σχέσης>.<όνοµα-γνωρίσµατος> Παράδειγµα φυσικής συνένωσης: Τους ηθοποιούς που παίζουν σε ασπρόµαυρες ταινίες select distinct Όνοµα from Παίζει, Ταινία where Παίζει.Τίτλος = Ταινία.Τίτλος and Παίζει.Έτος = Ταινία.Έτος and Είδος = Ασπρόµαυρη Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 22

Βασική οµή Ταινία (Τίτλος, Έτος, ιάρκεια, Είδος) Παίζει(Όνοµα, Τίτλος, Έτος) Ηθοποιός(Όνοµα, ιεύθυνση, Έτος-Γέννησης, Σύζυγος-Ηθοποιού) Παραδείγµατα Έγχρωµες ταινίες µε διάρκεια µέχρι 80 λεπτά Οι ηθοποιοί που γεννήθηκαν µετά το 1935 και έπαιξαν σε ασπρόµαυρες ταινίες πριν το 1945 Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 23 Η γλώσσα SQL Περισσότερα για τη γλώσσα ερωτήσεων - Πράξεις µε Συµβολοσειρές - ιάταξη Πλειάδων - Αλλαγή Ονόµατος - Μεταβλητές Πλειάδων - Πράξεις Συνόλων - Η τιµή null Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 24

Πράξεις µε Συµβολοσειρές Πράξεις µε Συµβολοσειρές Ηπιο συνηθισµένη πράξη είναι ταίριασµα προτύπων: % ταιριάζει οποιαδήποτε συµβολοσειρά _ ταιριάζει οποιοδήποτε χαρακτήρα Γίνεται διάκριση ανάµεσα σε κεφαλαία και µικρά Σύγκριση χρησιµοποιώντας το like, not like Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 25 Πράξεις µε Συµβολοσειρές Παράδειγµα: Οι τίτλοι όλων των ταινιών που περιέχουν τη λέξη Θάλασσα select distinct Τίτλος from Ταινία where Τίτλος like %Θάλασσα% Πολλές ακόµα πράξεις διαθέσιµες. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 26

ιάταξη των Πλειάδων ιάταξη των Πλειάδων Χρήση του order by ώστε οι πλειάδες στο αποτέλεσµα να είναι ταξινοµηµένες µε βάση τo αντίστοιχο γνώρισµα select distinct Ταινία, Έτος from Παίζει where Όνοµα = Robert De Niro order by Έτος Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 27 ιάταξη των Πλειάδων Default: αύξουσα διάταξη, αλλά και άµεσα χρησιµοποιώντας το asc (αύξουσα) ή το desc (φθήνουσα). Επίσης, ταξινόµηση µε βάση πολλά γνωρίσµατα. Παράδειγµα: select * from Ταινία order by Έτος desc, Τίτλος asc Ηταξινόµηση είναι δαπανηρή λειτουργία. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 28

Αλλαγή Ονόµατος Αλλαγή Ονόµατος Τα ονόµατα των γνωρισµάτων στο αποτέλεσµα είναι αυτά των σχέσεων στην ερώτηση. υνατότητα αλλαγής του ονόµατος τόσο µιας σχέσης όσο και ενός γνωρίσµατος: <παλιό-όνοµα> as <νέο-όνοµα> To as µπορεί να εµφανίζεται στο select ή στο from Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 29 Αλλαγή Ονόµατος Για παράδειγµα: select Τίτλος, Έτος, ιάρκεια / 60 as Ώρες- ιάρκεια, Είδος from Ταινία Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 30

Αλλαγή Ονόµατος Χρήσιµο όταν (α) όταν έχουµε αριθµητικές εκφράσεις στο select και δεν έχουν όνοµα, (β) όταν θέλουµε να αλλάξουµε το όνοµα του γνωρίσµατος στο αποτέλεσµα. (γ) δυο σχέσεις του from έχουν γνωρίσµατα µε το ίδιο όνοµα, Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 31 Μεταβλητές Πλειάδων Μεταβλητές Πλειάδων Μια µεταβλητή πλειάδας µπορεί να οριστεί στο from χρησιµοποιώντας το as: select distinct Όνοµα from Παίζει as Π, Ταινία as Τ where Π.Τίτλος = Τ.Τίτλος and Π.Έτος = Τ.Έτος and Είδος = Ασπρόµαυρη Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 32

Μεταβλητές Πλειάδων Οι µεταβλητές πλειάδων είναι ιδιαίτερα χρήσιµες όταν θέλουµε να συγκρίνουµε δυο πλειάδες της ίδιας σχέσης. Παράδειγµα: Τα ονόµατα όλων των ταινιών που έχουν διάρκεια µεγαλύτερη τουλάχιστον από µία ταινία που γυρίστηκε το 1995 select distinct Τ.Τίτλος from Ταινία as S, Ταινία as T where T. ιάρκεια > S. ιάρκεια and S.Έτος = 1995 Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 33 Πράξεις Συνόλων Πράξεις Συνόλων Πράξεις: union intersection except εφαρµόζονται σε συµβατές σχέσεις. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 34

Πράξεις Συνόλων Γενική Σύνταξη: ( select from where ) union/intersection/except ( select from where) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 35 Πράξεις Συνόλων Λογαριασµός Υποκατάστηµα Όνοµα-Υποκαταστήµατος Αριθµός-Λογαριασµού Όνοµα-Υποκαταστήµατος Πόλη Σύνολο Ποσό άνειο Όνοµα-Υποκαταστήµατος Αριθµός- ανείου Ποσό ανειζόµενος Όνοµα-Πελάτη Αριθµός- ανείου Πελάτης Όνοµα-Πελάτη Οδός Πόλη Καταθέτης Όνοµα-Πελάτη Αριθµός-Λογαριασµού Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 36

Πράξεις Συνόλων Παράδειγµα union: Τα ονόµατα όλων των πελατών που έχουν καταθέσεις ή/και έχουν πάρει δάνειο ( select Όνοµα-Πελάτη from Καταθέτης ) union ( select Όνοµα-Πελάτη from ανειζόµενος ) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 37 Πράξεις Συνόλων Απαλοιφή διπλών εµφανίσεων, εκτός αν χρησιµοποιηθεί το union all Μέγιστος αριθµός πολλαπλών εµφανίσεων; Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 38

Πράξεις Συνόλων Παράδειγµα intersect: Τα ονόµατα όλων των πελατών που έχουν καταθέσεις και έχουν πάρει δάνειο ( select Όνοµα-Πελάτη from Καταθέτης ) intersect ( select Όνοµα-Πελάτη from ανειζόµενος ) Αντίστοιχα υπάρχει το intersect all Μέγιστος αριθµός πολλαπλών εµφανίσεων; Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 39 Πράξεις Συνόλων Παράδειγµα except: Τα ονόµατα όλων των πελατών που έχουν καταθέσεις και δεν έχουν πάρει δάνειο ( select Όνοµα-Πελάτη from Καταθέτης ) except ( select Όνοµα-Πελάτη from ανειζόµενος ) Αντίστοιχα υπάρχει το except all Μέγιστος αριθµός πολλαπλών εµφανίσεων; Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 40

Η τιµή null Ητιµή null Χρήση της λέξης κλειδί is null (is not null) σε µια συνθήκη για να ελέξουµε αν µια τιµή είναι null. select Αριθµός- ανείου from άνειο where Ποσό is null Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 41 Η τιµή null Εµφάνιση null Σε αριθµητικές πράξεις: το αποτέλεσµα είναι null όταν οποιαδήποτε τιµή είναι null Σε συγκρίσεις: σύγκριση µε null συνήθως δίνει αποτέλεσµα false Σε συναθροιστικές συναρτήσεις: αγνοείται πλην από το count(*) Παράδειγµα: select sum(ποσό) from άνειο Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 42

Συναθροιστικές Συναρτήσεις Συναθροιστικές Συναρτήσεις Η SQL έχει 5 built-in συναθροιστικές συναρτήσεις: Μέσος όρος: avg(a) (µόνο σε αριθµούς) A γνώρισµα Ελάχιστο: min(a) Μέγιστο: max(a) Άθροισµα: sum(a) (µόνο σε αριθµούς) Πλήθος: count(a) Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 43 Συναθροιστικές Συναρτήσεις Λογαριασµός Υποκατάστηµα Όνοµα-Υποκαταστήµατος Αριθµός-Λογαριασµού Όνοµα-Υποκαταστήµατος Πόλη Σύνολο Ποσό άνειο Όνοµα-Υποκαταστήµατος Αριθµός- ανείου Ποσό ανειζόµενος Όνοµα-Πελάτη Αριθµός- ανείου Πελάτης Όνοµα-Πελάτη Οδός Πόλη Καταθέτης Όνοµα-Πελάτη Αριθµός-Λογαριασµού Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 44

Συναθροιστικές Συναρτήσεις Παράδειγµα: Μέσο ποσό όλων των λογαριασµών στο υποκατάστηµα Καλούτσανη select avg(ποσό) from Λογαριασµός where Όνοµα-Υποκαταστήµατος = Καλούτσανη Το αποτέλεσµα είναι µια σχέση µε ένα γνώρισµα και µια γραµµή, µπορούµε να δώσουµε όνοµα στο γνώρισµα χρησιµοποιώντας το as Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 45 Συναθροιστικές Συναρτήσεις Παράδειγµα: Μέγιστο ποσό όλων των λογαριασµών στο υποκατάστηµα Καλούτσανη και τον αριθµό του λογαριασµού!! select Αριθµός-Λογαριασµού, max(ποσό) from Λογαριασµός where Όνοµα-Υποκαταστήµατος = Καλούτσανη Αν το select συναθροιστική, τότε µόνο συναθροιστικές, εκτός αν υπάρχει group by Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 46

Συναθροιστικές Συναρτήσεις Μπορούµε να εφαρµόσουµε τις συναρτήσεις όχι µόνο σε ένα σύνολο από πλειάδες, αλλά σε οµάδες από σύνολα πλειάδων. Οι οµάδες προσδιορίζονται χρησιµοποιώντας το group by Παράδειγµα: Μέσο ποσό των λογαριασµών σε κάθε υποκατάστηµα select Όνοµα-Υποκαταστήµατος, avg(ποσό) from Λογαριασµός group by Όνοµα-Υποκαταστήµατος Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 47 Συναθροιστικές Συναρτήσεις Αν θέλουµε να απαλείψουµε διπλές εµφανίσεις χρησιµοποιούµε τη λέξη-κλειδί distinct στην αντίστοιχη έκφραση. Παράδειγµα: Αριθµός καταθετών σε κάθε υποκατάστηµα select Όνοµα-Υποκαταστήµατος, count(distinct Όνοµα-Πελάτη) from Καταθέτης, Λογαριασµός where group by Όνοµα-Υποκαταστήµατος Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 48

Συναθροιστικές Συναρτήσεις Ηοµαδοποίηση µπορεί να γίνει ως προς περισσότερα του ενός πεδία. Μέσος όρος καταθέσεων ανά πελάτη και ανά υποκατάστηµα SELECT Όνοµα-Υποκαταστήµατος, Όνοµα-Πελάτη, avg(balance) FROM account GROUP BY Όνοµα-Υποκαταστήµατος, Όνοµα-Πελάτη Οµαδοποίηση γίνεται πρώτα ως προς το branch_name. Στην συνέχεια δηµιουργούνται υποoµάδες ως προς το customer_name Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 49 Συναθροιστικές Συναρτήσεις Μπορούµε να εφαρµόσουµε µια συνθήκη σε µια συγκεκριµένη οµάδα από πλειάδες χρησιµοποιώντας το having Παράδειγµα: Ονόµατα υποκαταστηµάτων µε µέσο ποσό καταθέσεων µεγαλύτερο των $1200 select Όνοµα-Υποκαταστήµατος, avg(ποσό) from Λογαριασµός group by Όνοµα-Υποκαταστήµατος having avg(ποσό) > 1200 Ησυνθήκη του having εφαρµόζεται αφού σχηµατιστούν οι οµάδες και υπολογιστούν οι συναθροιστικές συναρτήσεις. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 50

Συναθροιστικές Συναρτήσεις 'Οταν εµφανίζονται και το where και το having: η συνθήκη του where εφαρµόζεται πρώτα, οι πλειάδες που ικανοποιούν αυτή τη συνθήκη τοποθετούνται σε οµάδες µε βάση το group by και µετά αν υπάρχει συνθήκη στο having εφαρµόζεται στις οµάδες. Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 51 Συναθροιστικές Συναρτήσεις Παράδειγµα: Μέσο ποσό για κάθε πελάτη που ζει στα Ιωάννινα και έχει τουλάχιστον τρεις λογαριασµούς 1 2 4 select Καταθέτης.Όνοµα-Πελάτη, avg(ποσό) from Καταθέτης, Λογαριασµός, Πελάτης where Καταθέτης.Αριθµός-Λογαριασµού = Λογαριασµός. Αριθµός- Λογαριασµού and Καταθέτης. Όνοµα-Πελάτη = Πελάτης. Όνοµα- Πελάτη and Πόλη = Ιωάννινα group by Καταθέτης. Όνοµα-Πελάτη having count (distinct Καταθέτης.Αριθµός-Λογαριασµού) >= 3 3 Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 52

Συναθροιστικές Συναρτήσεις Για να µετρήσουµε πόσες πλειάδες έχει µια σχέση: select count (*) from Πελάτης ε µπορούµε να χρησιµοποιήσουµε το distinct µε το count (*). Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 53 Περίληψη Μέσος όρος: avg (µόνο σε αριθµούς) Ελάχιστο: min Μέγιστο: max Άθροισµα: sum (µόνο σε αριθµούς) Πλήθος: count Συναθροιστικές Συναρτήσεις Αν θέλουµε να απαλείψουµε διπλές εµφανίσεις χρησιµοποιούµε τη λέξηκλειδί distinct στην αντίστοιχη έκφραση. Μπορούµε να εφαρµόσουµε τις συναρτήσεις όχι µόνο σε ένα σύνολο από πλειάδες, αλλά σε οµάδες από σύνολα πλειάδων. Οι οµάδες προσδιορίζονται χρησιµοποιώντας το group by Μπορούµε να εφαρµόσουµε µια συνθήκη σε µια συγκεκριµένη οµάδα από πλειάδες χρησιµοποιώντας το having. Η συνθήκη του having εφαρµόζεται αφού σχηµατιστούν οι οµάδες και υπολογιστούν οι συναθροιστικές συναρτήσεις Βάσεις εδοµένων 2002-2003 Ευαγγελία Πιτουρά 54