atzeni, ceri, paraboschi, torlone basi di dati mcgraw-hill, 1999

75
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999 Capitolo 3: ALGEBRA E CALCOLO ALGEBRA E CALCOLO RELAZIONALE RELAZIONALE 09/10/2001

Upload: igor-guerra

Post on 03-Jan-2016

36 views

Category:

Documents


1 download

DESCRIPTION

Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999. Capitolo 3: ALGEBRA E CALCOLO RELAZIONALE 0 9 /10/2001. Linguaggi per basi di dati. operazioni sullo schema DDL: data definition language operazioni sui dati DML: data manipulation language interrogazione ("query") - PowerPoint PPT Presentation

TRANSCRIPT

Page 1: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

Atzeni, Ceri, Paraboschi, TorloneBasi di dati

McGraw-Hill, 1999

Capitolo 3:

ALGEBRA E CALCOLO ALGEBRA E CALCOLO RELAZIONALERELAZIONALE

09/10/2001

Page 2: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

2

Linguaggi per basi di dati

• operazioni sullo schema• DDL: data definition language

• operazioni sui dati• DML: data manipulation language

• interrogazione ("query")• aggiornamento

Page 3: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

3

Linguaggi di interrogazioneper basi di dati relazionali

• Dichiarativi• specificano le proprietà del risultato

("che cosa")• Procedurali

• specificano le modalità di generazione del risultato ("come")

Page 4: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

4

Linguaggi di interrogazione

• Algebra relazionale: procedurale• Calcolo relazionale:

dichiarativo (teorico)• SQL (Structured Query Language):

parzialmente dichiarativo (reale)• QBE (Query by Example):

dichiarativo (reale)

Page 5: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

5

Algebra relazionale

• Insieme di operatori• su relazioni• che producono relazioni• e possono essere composti

Page 6: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

6

Operatori dell'algebra relazionale

• unione, intersezione, differenza• ridenominazione• selezione• proiezione• join (join naturale, prodotto cartesiano,

theta-join)

Page 7: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

7

Operatori insiemistici

• le relazioni sono insiemi• i risultati debbono essere relazioni• è possibile applicare unione,

intersezione, differenza solo a relazioni definite sugli stessi attributi

Page 8: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

8

Laureati

Matricola

74329824

Età

5445

Nome

NeriVerdi

7274 42Rossi

Quadri

Matricola

74329824

9297Età

5445

33Nome

NeriVerdi

Neri

Laureati Quadri

Matricola EtàNome

7432 54Neri9824 45Verdi9297 33Neri

7274 42Rossi7432 54Neri9824 45Verdi

7274 42Rossi7432 54Neri9824 45Verdi9297 33Neri

7432 54Neri9824 45Verdi9297 33Neri

7274 42Rossi

Unione

Page 9: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

9

Laureati

Matricola

74329824

Età

5445

Nome

NeriVerdi

7274 42Rossi

Quadri

Matricola

74329824

9297Età

5445

33Nome

NeriVerdi

Neri

Laureati Quadri

Matricola EtàNome7432 54Neri9824 45Verdi

7432 54Neri9824 45Verdi

7432 54Neri9824 45Verdi

7432 54Neri9824 45Verdi

Intersezione

Page 10: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

10

Laureati

Matricola EtàNome

7432 54Neri9824 45Verdi

7274 42Rossi

Quadri

Matricola

74329824

9297Età

5445

33Nome

NeriVerdi

Neri

Laureati – Quadri

Matricola EtàNome

7432 54Neri9824 45Verdi

7274 42Rossi7432 54Neri9824 45Verdi

7274 42Rossi

Differenza

Page 11: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

11

Paternità

Padre Figlio

Adamo CainoAbramo Isacco

Adamo Abele

Maternità

Madre Figlio

Eva SetSara Isacco

Eva Abele

Paternità Maternità

??

Una unione sensata ma impossibile

Page 12: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

12

Ridenominazione

• operatore monadico (con un argomento)• "modifica lo schema" lasciando

inalterata l'istanza dell'operando

Page 13: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

13

Paternità

Padre Figlio

Adamo CainoAbramo Isacco

Adamo Abele

RENGenitore Padre (Paternità)

Padre Figlio

Adamo CainoAbramo Isacco

Adamo AbeleGenitore

Page 14: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

14

Paternità

Padre Figlio

Adamo CainoAbramo Isacco

Adamo Abele

Maternità

Madre Figlio

Eva SetSara Isacco

Eva Abele

RENGenitore Padre (Paternità)

RENGenitore Madre (Maternità)

Genitore Figlio

Adamo CainoAbramo Isacco

Adamo Abele

Genitore Figlio

Eva SetSara Isacco

Eva Abele

Page 15: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

15

RENGenitore Padre (Paternità)

RENGenitore Madre (Maternità)

Genitore Figlio

Adamo CainoAbramo Isacco

Adamo Abele

Genitore Figlio

Eva SetSara Isacco

Eva Abele

Genitore Figlio

Adamo CainoAbramo Isacco

Adamo Abele

Eva SetSara Isacco

Eva Abele

RENGenitore Padre (Paternità)

RENGenitore Madre (Maternità)

Page 16: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

16

REN Sede, Retribuzione Ufficio, Stipendio (Impiegati)

REN Sede, Retribuzione Fabbrica, Salario (Operai)

Impiegati Cognome

NeriRossi

Ufficio

MilanoRoma

Stipendio

6455

Operai Cognome

VerdiBruni

Fabbrica

LatinaMonza

Salario

5545

Cognome RetribuzioneSede

NeriRossi

6455

MilanoRoma

VerdiBruni

LatinaMonza

5545

Page 17: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

17

Selezione

• operatore monadico• produce un risultato che

• ha lo stesso schema dell'operando• contiene un sottoinsieme delle

ennuple dell'operando,• quelle che soddisfano una condizione

Page 18: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

18

Impiegati Cognome Filiale StipendioMatricola

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553

• impiegati che • guadagnano più di 50 • guadagnano più di 50 e lavorano a Milano• hanno lo stesso nome della filiale presso

cui lavorano

Page 19: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

19

Selezione, sintassi e semantica

• sintassiSEL Condizione (Operando)

• Condizione: espressione booleana (come quelle dei vincoli di ennupla)

• semantica• il risultato contiene le ennuple

dell'operando che soddisfano la condizione

Page 20: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

20

Cognome Filiale StipendioMatricola

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553

Impiegati

Milano Milano 449553 Neri Napoli 645698

• impiegati che guadagnano più di 50

SELStipendio > 50 (Impiegati)

Page 21: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

21

Impiegati Cognome Filiale StipendioMatricola

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553

• impiegati che guadagnano più di 50 e lavorano a Milano

SELStipendio > 50 AND Filiale = 'Milano' (Impiegati)

Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553

Neri Milano 645998

Page 22: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

22

Impiegati Cognome Filiale StipendioMatricola

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553

• impiegati che hanno lo stesso nome della filiale presso cui lavorano

SEL Cognome = Filiale(Impiegati)

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698

Milano Milano 449553

Page 23: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

23

Selezione con valori nulli

Cognome Filiale EtàMatricola

Neri Milano 455998Rossi Roma 327309

Bruni Milano NULL9553

Impiegati

SEL Età > 40 (Impiegati)

• la condizione atomica è vera solo per valori non nulli

Page 24: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

24

Un risultato non desiderabile

SEL Età>30 (Persone) SEL Età30 (Persone) Persone

• Perché? Perché le selezioni vengono valutate separatamente!

• Ma anche SEL Età>30 Età30 (Persone) Persone

• Perché? Perché anche le condizioni atomiche vengono valutate separatamente!

Page 25: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

25

SEL Età > 40 (Impiegati)

• la condizione atomica è vera solo per valori non nulli

• per riferirsi ai valori nulli esistono forme apposite di condizioni:

IS NULLIS NOT NULL

• si potrebbe usare (ma non serve) una "logica a tre valori" (vero, falso, sconosciuto)

Page 26: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

26

• A questo punto:SEL Età>30 (Persone) SEL Età30 (Persone)

SEL Età IS NULL (Persone)

=SEL Età>30 Età30 Età IS NULL (Persone)

= Persone

Page 27: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

27

Cognome Filiale EtàMatricola

Neri Milano 455998Rossi Roma 327309

Bruni Milano NULL9553

Impiegati

Neri Milano 455998Bruni Milano NULL9553

SEL (Età > 40) OR (Età IS NULL) (Impiegati)

Neri Milano 455998Bruni Milano NULL9553

Page 28: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

28

Selezione e proiezione

• operatori "ortogonali"• selezione:

• decomposizione orizzontale• proiezione:

• decomposizione verticale

Page 29: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

29

selezione

proiezione

Page 30: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

30

Proiezione

• operatore monadico• produce un risultato che

• ha parte degli attributi dell'operando• contiene ennuple cui contribuiscono

tutte le ennuple dell'operando

Page 31: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

31

Impiegati Cognome Filiale StipendioMatricola

Neri Milano 645998Neri Napoli 557309

Rossi Roma 645698Rossi Roma 449553

• per tutti gli impiegati:• matricola e cognome• cognome e filiale

Page 32: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

32

Proiezione, sintassi e semantica

• sintassiPROJ ListaAttributi (Operando)

• semantica• il risultato contiene le ennuple

ottenute da tutte le ennuple dell'operando ristrette agli attributi nella lista

Page 33: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

33

Cognome Filiale StipendioMatricola

Neri Milano 645998Neri Napoli 557309

Rossi Roma 645698Rossi Roma 449553

• matricola e cognome di tutti gli impiegati

PROJ Matricola, Cognome (Impiegati)

Page 34: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

34

Cognome Filiale StipendioMatricola

Neri Milano 645998Neri Napoli 557309

Rossi Roma 645698Rossi Roma 449553

• cognome e filiale di tutti gli impiegati

PROJ Cognome, Filiale (Impiegati)

Page 35: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

35

Cardinalità delle proiezioni

• una proiezione• contiene al più tante ennuple quante

l'operando• può contenerne di meno

• se X è una superchiave di R, allora PROJX(R) contiene esattamente tante ennuple quante R

Page 36: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

36

Selezione e proiezione

• Combinando selezione e proiezione, possiamo estrarre interessanti informazioni da una relazione

Page 37: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

37

Cognome Filiale StipendioMatricola

Neri Milano 645998Rossi Roma 557309

Neri Napoli 645698Milano Milano 449553 Milano Milano 449553 Neri Napoli 645698

• matricola e cognome degli impiegati che guadagnano più di 50

SELStipendio > 50 (Impiegati) PROJMatricola,Cognome ( )

Page 38: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

38

• Combinando selezione e proiezione, possiamo estrarre informazioni da una relazione

• non possiamo però correlare informazioni presenti in relazioni diverse

Page 39: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

39

Join

• il join è l'operatore più interessante dell'algebra relazionale

• permette di correlare dati in relazioni diverse

Page 40: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

40

Prove scritte in un concorso pubblico

• I compiti sono anonimi e ad ognuno è associata una busta chiusa con il nome del candidato

• Ciascun compito e la relativa busta vengono contrassegnati con uno stesso numero

Page 41: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

41

1 252 133 274 28

1 Mario Rossi2 Nicola Russo3 Mario Bianchi4 Remo Neri

25Mario Rossi13Nicola Russo27Mario Bianchi28Remo Neri

Page 42: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

42

1 252 133 274 28

Numero Voto1 Mario Rossi2 Nicola Russo3 Mario Bianchi4 Remo Neri

Numero Candidato

25Mario Rossi13Nicola Russo27Mario Bianchi28Remo Neri

VotoCandidato1234

Numero

Page 43: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

43

Join naturale

• operatore binario (generalizzabile)• produce un risultato

• sull'unione degli attributi degli operandi

• con ennuple costruite ciascuna a partire da una ennupla di ognuno degli operandi

Page 44: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

44

Join, sintassi e semantica

• R1(X1), R2(X2)

• R1 JOIN R2 è una relazione su X1X2

{ t su X1X2 | esistono t1R1e t2R2

con t[X1] =t1 e t[X2] =t2 }

Page 45: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

45

A MoriB Bruni

Reparto CapoRossi ANeri B

Bianchi B

Impiegato Reparto

Rossi A MoriNeri B Bruni

Impiegato Reparto Capo

Bianchi B Bruni

Rossi ANeri B

Bianchi B

Rossi ANeri B

Bianchi B

A MoriB BruniA MoriB BruniB BruniB Bruni

• ogni ennupla contribuisce al risultato:• join completo

Page 46: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

46

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

Impiegato RepartoRossi ANeri B

Bianchi B

Reparto CapoB MoriC Bruni

AC

Un join non completo

Page 47: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

47

Impiegato RepartoRossi ANeri B

Bianchi B

Reparto CapoD MoriC Bruni

Impiegato Reparto Capo

Un join vuoto

Page 48: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

48

Rossi B Mori

Neri B Mori

Impiegato Reparto Capo

Bianchi B Bruni

Rossi ANeri B

Impiegato RepartoRossi ANeri B

Rossi BNeri B

A MoriB Bruni

Reparto CapoA MoriB BruniB MoriB BruniB BruniB Bruni

Rossi B Bruni

Un join completo, con n x m ennuple

Page 49: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

49

Cardinalità del join

• Il join di R1 e R2 contiene un numero di ennuple compreso fra zero e il prodotto di |R1| e |R2|

• se il join coinvolge una chiave di R2, allora il numero di ennuple è compreso fra zero e |R1|

• se il join coinvolge una chiave di R2 e un vincolo di integrità referenziale, allora il numero di ennuple è pari a |R1|

Page 50: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

50

Cardinalità del join, esempi

• R1(A,B) , R2 (B,C)• in generale

0 |R1 JOIN R2| |R1| |R2| • se B è chiave in R2

0 |R1 JOIN R2| |R1|• se B è chiave in R2 ed esiste vincolo di

integrità referenziale fra B (in R1) e R2:|R1 JOIN R2| = |R1|

Page 51: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

51

Impiegato RepartoRossi ANeri B

Bianchi B

Reparto CapoB MoriC Bruni

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

AC

Join, una difficoltà

• alcune ennuple non contribuiscono al risultato: vengono "tagliate fuori"

Page 52: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

52

Join esterno

• Il join esterno estende, con valori nulli, le ennuple che verrebbero tagliate fuori da un join (interno)

• esiste in tre versioni:• sinistro, destro, completo

Page 53: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

53

Join esterno

• sinistro: mantiene tutte le ennuple del primo operando, estendendole con valori nulli, se necessario

• destro: ... del secondo operando ...• completo: … di entrambi gli operandi ...

Page 54: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

54

Impiegato RepartoRossi ANeri B

Bianchi B

ImpiegatiReparto Capo

B MoriC Bruni

Reparti

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

Impiegati JOINLEFT Reparti

C

Rossi A NULL

ARossi

Page 55: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

55

Impiegato RepartoRossi ANeri B

Bianchi B

ImpiegatiReparto Capo

B MoriC Bruni

Reparti

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

Impiegati JOINRIGHT Reparti

A

NULL C Bruni

C Bruni

Page 56: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

56

Impiegato RepartoRossi ANeri B

Bianchi B

ImpiegatiReparto Capo

B MoriC Bruni

Reparti

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

Impiegati JOINFULL Reparti

NULL C Bruni

C BruniARossi

Rossi A NULL

Page 57: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

57

Join e proiezioni

Impiegato RepartoRossi ANeri B

Bianchi B

Reparto CapoB MoriC Bruni

Neri B MoriImpiegato Reparto Capo

Bianchi B Mori

Impiegato RepartoNeri B

Bianchi B

Reparto CapoB Mori

Page 58: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

58

Proiezioni e join

Neri B MoriImpiegato Reparto Capo

Bianchi B BruniVerdi A Bini

Neri BImpiegato Reparto

Bianchi BVerdi A

B MoriReparto Capo

B BruniA Bini

Verdi A Bini

Neri B MoriImpiegato Reparto Capo

Bianchi B BruniNeri B Bruni

Bianchi B Mori

Page 59: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

59

Join e proiezioni

• R 1(X1), R 2(X2)

PROJX1 (R 1 JOIN R2 ) R 1

• R(X), X = X1 X2

(PROJX1 (R)) JOIN (PROJX2

(R)) R

Page 60: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

60

Prodotto cartesiano

• un join naturale su relazioni senza attributi in comune

• contiene sempre un numero di ennuple pari al prodotto delle cardinalità degli operandi (le ennuple sono tutte combinabili )

Page 61: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

61

Rossi ANeri B

Bianchi B

Impiegato Reparto

Impiegati

A MoriB BruniB BruniB Bruni

Codice Capo

Reparti

Impiegati JOIN Reparti

Impiegato Reparto CapoCodiceRossi A MoriAAARossi A B BruniNeri B MoriANeri B B Bruni

Bianchi B MoriABianchi B B Bruni

Page 62: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

62

• Il prodotto cartesiano, in pratica, ha senso solo se seguito da selezione:

SELCondizione (R1 JOIN R2)

• L'operazione viene chiamata theta-join e indicata con

R1 JOINCondizione R2

Page 63: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

63

Perché "theta-join"?

• La condizione C è spesso una congiunzione (AND) di atomi di confronto A1 A2 dove è uno degli operatori di confronto (=, >, <, …)

• se l'operatore è sempre l'uguaglianza (=) allora si parla di equi-join

Page 64: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

64

Rossi ANeri B

Bianchi B

Impiegato Reparto

Impiegati

A MoriB BruniB BruniB Bruni

Codice Capo

Reparti

Impiegati JOINReparto=Codice Reparti

Impiegato Reparto CapoCodiceRossi A MoriAAARossi A B BruniNeri B MoriANeri B B Bruni

Bianchi B MoriABianchi B B Bruni

Rossi A MoriAAANeri B B Bruni

Bianchi B B Bruni

Page 65: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

65

Rossi ANeri B

Bianchi B

Impiegato Reparto

Impiegati

A MoriB BruniB BruniB Bruni

Reparto Capo

Reparti

Impiegati JOIN Reparti

Page 66: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

66

Join naturale ed equi-join

Impiegato Reparto

Impiegati

Reparto Capo

Reparti

Impiegati JOIN Reparti

PROJImpiegato,Reparto,Capo (

)RENCodice Reparto (Reparti)Impiegati JOIN

SELReparto=Codice

( )

Page 67: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

67

Esempi

Impiegati Nome Età StipendioMatricola

Bianchi 37 385998Rossi 34 457309

Bruni 43 425698Neri 42 359553

Mori 45 504076Lupi 46 608123

Supervisione Impiegato Capo

59987309

56989553

4076

56985698

40764076

8123

Page 68: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

68

• Trovare matricola, nome, età e stipendio degli impiegati che guadagnano più di 40 milioni

SELStipendio>40(Impiegati)

Page 69: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

69

Nome Età StipendioMatricola

Bianchi 37 385998Rossi 34 457309

Bruni 43 425698Neri 42 359553

Mori 45 504076Lupi 46 608123

SELStipendio>40(Impiegati)

Bianchi 37 385998Neri 42 359553

Rossi 34 457309

Bruni 43 425698Mori 45 504076Lupi 46 608123

Rossi 34 457309Bruni 43 425698Mori 45 504076Lupi 46 608123

Page 70: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

70

• Trovare matricola, nome ed età degli impiegati che guadagnano più di 40 milioni

PROJMatricola, Nome, Età (SELStipendio>40(Impiegati))

Page 71: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

71

Nome Età StipendioMatricola

Bianchi 37 385998Rossi 34 457309

Bruni 43 425698Neri 42 359553

Mori 45 504076Lupi 46 608123

Bianchi 37 385998Neri 42 359553

Rossi 34 457309

Bruni 43 425698Mori 45 504076Lupi 46 608123

Rossi 34 457309Bruni 43 425698Mori 45 504076Lupi 46 608123

SELStipendio>40(Impiegati)PROJMatricola, Nome, Età

( )

Page 72: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

72

• Trovare le matricole dei capi degli impiegati che guadagnano più di 40 milioni

PROJCapo (Supervisione JOIN Impiegato=Matricola

(SELStipendio>40(Impiegati)))

Page 73: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

73

• Trovare nome e stipendio dei capi degli impiegati che guadagnano più di 40 milioni

PROJNome,Stipendio (Impiegati JOIN Matricola=Capo

PROJCapo(Supervisione JOIN Impiegato=Matricola (SELStipendio>40(Impiegati))))

Page 74: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

74

• Trovare gli impiegati che guadagnano più del proprio capo, mostrando matricola, nome e stipendio dell'impiegato e del capo

PROJMatr,Nome,Stip,MatrC,NomeC,StipC

(SELStipendio>StipC(RENMatrC,NomeC,StipC,EtàC Matr,Nome,Stip,Età(Impiegati)

JOIN MatrC=Capo

(Supervisione JOIN Impiegato=Matricola Impiegati)))

Page 75: Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999

9/10/2001 Atzeni-Ceri-Paraboschi-Torlone, Basi di dati, Capitolo 3

75

• Trovare le matricole dei capi i cui impiegati guadagnano tutti più di 40 milioni

PROJCapo (Supervisione) -

PROJCapo (Supervisione JOIN Impiegato=Matricola

(SELStipendio 40(Impiegati)))