Università di Roma La Sapienza Laurea in Ingegneria Informatica. Basi di Dati. Anno Accademico 2003/2004 Canale M-Z.

Documenti analoghi
Basi di dati. 2. Il modello relazionale. Il modello relazionale. Relazione: tre accezioni. 2.1 Basi di dati relazionali. Giuseppe De Giacomo

Linguaggi per basi di dati

Modulo 2 Data Base - Modello Relazionale

SQL. Il nome sta per Structured Query Language Le interrogazioni SQL sono dichiarative

Partite string string int int. Perché studiare il Modello Relazionale? Capitolo 2. Relazione: tre accezioni. Basi di dati relazionali: definizioni

Algebra e calcolo relazionale. Ripasso. Le 7 Virtù del DBMS persistenza affidabilità volume condivisione riservatezza efficienza efficacia

V. Moriggia Modelli di Base Dati. Modelli di Base Dati. a.a. 2001/

Modulo 2 Data Base 2

Normalizzazione. Definizione

I database. Introduzione alla teoria delle basi di dati

Indicare quale o quali delle seguenti affermazioni sono vere?

CONCETTI E ARCHITETTURA DI UN SISTEMA DI BASI DI DATI

BASI DATI: algebra relazionale

Il linguaggio SQL: query innestate

Architettura CPU. Memoria principale (RAM) Dispositivi di ingresso. Dispositivi di uscita. Memoria secondaria (memoria di massa)

Algebra Relazionale e Calcolo Relazionale. L. Vigliano

INTRODUZIONE ALLE BASI DATI RELAZIONALI

Capitolo 9. Esercizio 9.1. Esercizio 9.2

Operatori di base. σ F (r) = {t t r. F(t) = true} SELEZIONE σ F (r)

APPUNTI DELLA LEZIONE DI DATABASE DEL 26/10/2016 Studenti: Marco D'Amato, Adriano Luigi Piscopello Professore: Mario Bochicchio

Progettazione logica

BASE DI DATI: sicurezza. Informatica febbraio ASA

CAPITOLO V. DATABASE: Il modello relazionale

Vincoli di integrità

Riconoscere e formalizzare le dipendenze funzionali

La in verifica forma teoria normale della normalizzazione fornisce comunque uno strumento di già

1 Il Modello Relazionale

Matematica e-learning - Corso Zero di Matematica. Gli Insiemi. Prof. Erasmo Modica A.A.

SQL - Sottointerrogazioni

Codice binario. Codice. Codifica - numeri naturali. Codifica - numeri naturali. Alfabeto binario: costituito da due simboli

Algebra di Boole Algebra di Boole

Per lavorare sulle tabelle è utile separare la loro struttura (fissa) dal contenuto (che varierà nel tempo) , nome_attr 2. Schema di relazione

04 - Numeri Complessi

Il sistema informativo deve essere di tipo centralizzato e accessibile mediante un computer server installato nella rete locale dell albergo.

LABORATORIO di INFORMATICA

Alessandra Raffaetà. Esempio: Compagnia di trasporti

APPUNTI DI MATEMATICA ALGEBRA \ CALCOLO LETTERALE \ MONOMI (1)

SQL. Definizione dei da6 in SQL. SQL: "storia" CREATE TABLE: esempio. CREATE TABLE: esempio

Parte 6 Esercitazione sull accesso ai file

Esempio di database relazionale con l utilizzo del prodotto MySQL

Dichiarazione degli schemi in SQL DDL 1

Esame di INFORMATICA (*) Operazioni Aritmetiche: Somma. Lezione 3. Operazioni Aritmetiche: Somma. Operazioni Aritmetiche: Somma

SQL: concetti base SQL. Definizione dei dati in SQL. SQL: "storia"

Linguaggio SQL. studenti matricola nome cognome citta anno 11 marco bini bologna laura sicuro rimini 1984 esami codice

Il modello relazionale

Basi di dati. Il Modello Relazionale dei Dati. K. Donno - Il Modello Relazionale dei Dati

Modello Relazionale dei DBMS - Vincoli Tradizionalmente, esistono quattro modelli logici: Gerarchico Reticolare Relazionale A oggetti XML I modelli

Algebra Relazionale. algebra relazionale

Database. Cos è un database? Intro Tipi di entità Mapping ER/EER à Relazionale

IL MODELLO ENTITY RELATIONSHIP. il modello ER 1

Modulo 1: Le I.C.T. UD 1.2d: La codifica Digitale dei caratteri

SQL terza parte D O C E N T E P R O F. A L B E R T O B E L U S S I. Anno accademico 2010/11

AXO - Architettura dei Calcolatori e Sistema Operativo. organizzazione strutturata dei calcolatori

I RADICALI QUADRATICI

Heap e code di priorità

TEORIA RELAZIONALE: INTRODUZIONE

Concetti Introduttivi. Il Computer

SQL [2] Concetti avanzati di SQL. Esempi di interrogazioni

Università degli Studi di Milano. Esercizi Corso SIT. Basi di dati

Analisi. Calcolo Combinatorio. Ing. Ivano Coccorullo

Metodi e Modelli per l Ottimizzazione Combinatoria Ripasso sulla Programmazione Lineare e il metodo del Simplesso (parte I)

1 Definizione di sistema lineare omogeneo.

OPERAZIONI SULLA STRUTTURA

= < < < < < Matematica 1

Somma di numeri floating point. Algoritmi di moltiplicazione e divisione per numeri interi

Lezione 4. Sommario. L artimetica binaria: I numeri relativi e frazionari. I numeri relativi I numeri frazionari

BASI DI DATI. basi di dati - introduzione ai sistemi informativi 1

MODELLO RELAZIONALE. Introduzione

Compito Sistemi Informativi LA. Tempo concesso : 90 minuti 28 Giugno 05 Nome: Cognome: Matricola: Esercizio 1

La codifica. dell informazione

7 Disegni sperimentali ad un solo fattore. Giulio Vidotto Raffaele Cioffi

SOTTOSPAZI E OPERAZIONI IN SPAZI DIVERSI DA R n

1.2d: La codifica Digitale dei caratteri

SISTEMI INFORMATIVI AZIENDALI. introduzione ai sistemi informativi 1

TEOREMA DEL RESTO E REGOLA DI RUFFINI

Introduzione al linguaggio Fortran 90

SUI SISTEMI DI DISEQUAZIONI IN DUE INCOGNITE

1 IL LINGUAGGIO MATEMATICO

Anno 3. Funzioni esponenziali e logaritmi: le 4 operazioni

Corso di Sistemi di Elaborazione delle informazioni

Rappresentazioni numeriche

Il modello relazionale

Prof.ssa Laura Pagnozzi Prof. Ivano Coccorullo. Calcolo Combinatorio

Definizione: Dato un sottoinsieme non vuoti di. Si chiama funzione identica o identità di in sé la funzione tale che.

SISTEMI LINEARI MATRICI E SISTEMI 1

Matematica - Sessione 2 / Produzione a.f.2015/2016 Esame di Diploma (IV Livello Europeo) Quarto Anno

La divisione esatta fra a e b è l operazione che dati i numeri a e b (con a multiplo di b) permette di trovare un terzo numero c tale che c b = a.

1. riconoscere la risolubilità di equazioni e disequazioni in casi particolari

Il modello relazionale

Basi di Dati. S Q L Lezione 2

Modello Relazionale. Modello Relazionale. Relazioni - Prodotto Cartesiano. Relazione: tre accezioni. Es. Dati gli insiemi

codifica in virgola mobile (floating point)

SISTEMI OPERATIVI, RETI, INTERNET

SCHEDA DI VALUTAZIONE DELLE COMPETENZE. Tecnico Professionali Specifiche

Programma del corso. Introduzione Rappresentazione delle Informazioni Calcolo proposizionale Architettura del calcolatore Reti di calcolatori

Unità Didattica 2 I Linguaggi di Programmazione

Equazioni, funzioni e algoritmi: il metodo delle secanti

Esercitazioni di statistica

Elena Baralis 2013 Politecnico di Torino 1

FILE E INDICI Architettura DBMS

Transcript:

Università di Roma La Sapienza Laurea in Ingegneria Informatica Basi di Dati Anno Accademico 2003/2004 Canale M-Z Diego Calvanese Dipartimento di Informatica e Sistemistica Antonio Ruberti Università di Roma La Sapienza http://www.dis.uniroma1.it/~calvanese/didattica/03-04-basididati/

2. Il modello relazionale 2.1 Basi di dati relazionali 1. basi di dati relazionali 2. algebra relazionale Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 2

Il modello relazionale Proposto da E. F. Codd nel 1970 per favorire l indipendenza dei dati Disponibile come modello logico in DBMS reali nel 1981 (non è facile realizzare l indipendenza con efficienza e affidabilità!) Si basa sul concetto matematico di relazione (con una variante) Le relazioni hanno una rappresentazione naturale per mezzo di tabelle Il modello è "basato su valori : anche i riferimenti fra dati in strutture (relazioni) diverse sono rappresentati per mezzo dei valori stessi Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 3

Relazione: tre accezioni relazione matematica: come nella teoria degli insiemi relazione (dall inglese relationship) che rappresenta una classe di fatti una relazione matematica fra due entità, nel modello Entity-Relationship; talvolta tradotto con associazione o correlazione relazione secondo il modello relazionale dei dati: tabella Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 4

Relazione matematica D 1, D 2,, D n (n insiemi anche non distinti) il prodotto cartesiano D 1 D 2 D n, è l insieme di tutte le n- uple ordinate (d 1, d 2,, d n ) tali che d 1 D 1, d 2 D 2,, d n D n una relazione matematica su D 1, D 2,, D n è un sottoinsieme del prodotto cartesiano D 1 D 2 D n D 1, D 2,, D n sono i domini della relazione. Una relazione su n domini ha grado (o arietà) n il numero di n-uple è la cardinalità della relazione Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 5

Relazione matematica, esempio D 1 = { a, b } D 2 = { x, y, z } prodotto cartesiano D 1 D 2 una relazione r D 1 D 2 a a a b b b a a b b x y z x y z x z y z Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 6

Relazione matematica, proprietà Una relazione matematica è un insieme di n-uple ordinate: (d 1,, d n ) tali che d 1 D 1,, d n D n la relazione è un insieme; quindi: non c'è ordinamento fra le n-uple le n-uple sono distinte ciascuna n-upla è ordinata; quindi l i-esimo valore proviene dall i-esimo dominio Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 7

Relazione matematica, esempio Partite string string integer integer Juve Lazio 3 1 Lazio Milan 2 0 Juve Roma 1 2 Roma Milan 0 1 Ciascuno dei domini ha due ruoli distinti, distinguibili attraverso la posizione: il primo e il terzo dominio si riferiscono a nome e reti della squadra ospitante; il secondo e il quarto a nome e reti della squadra ospitata La struttura è posizionale Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 8

Relazioni nel modello relazionale dei dati Ogni relazione è sostanzialmente una tabella A ciascun dominio associamo un nome (attributo), unico nella relazione, che descrive il ruolo del dominio Nella rappresentazione tabellare, gli attributi sono usati come intestazioni delle colonne Casa Fuori RetiCasa RetiFuori Juve Lazio 3 1 Lazio Milan 2 0 Juve Roma 1 2 Roma Milan 0 1 L ordinamento fra gli attributi è irrilevante: la struttura è non posizionale Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 9

Notazioni Se t è una ennupla su X e A X, allora t[a] (oppure t.a) indica il valore di t su A Nell esempio, se t è la prima ennupla della tabella t[fuori] = Lazio La stessa notazione è estesa anche ad insiemi di attributi, nel qual caso denota ennuple: t[fuori,retifuori] è una ennupla su due attributi. Nell esempio, se t è la prima ennupla della tabella t[fuori,retifuori] = <Lazio, 1> Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 10

Tabelle e relazioni Una tabella rappresenta una relazione se i valori di ciascuna colonna sono fra loro omogenei (appartengono allo stesso dominio) le righe sono diverse fra loro le intestazioni delle colonne (attributi) sono diverse tra loro Inoltre, in una tabella che rappresenta una relazione l ordinamento tra le righe è irrilevante l ordinamento tra le colonne è irrilevante Il modello relazionale è basato su valori: i riferimenti fra dati in relazioni diverse sono rappresentati per mezzo di valori dei domini che compaiono nelle ennuple. Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 11

studenti Matricola Cognome Nome Data di nascita 6554 Rossi Mario 05/12/1978 8765 Neri Paolo 03/11/1976 9283 Verdi Luisa 12/11/1979 3456 Rossi Maria 01/02/1978 esami Studente Voto Corso 3456 30 04 3456 24 02 9283 28 01 6554 26 01 corsi Codice Titolo Docente 01 Analisi Mario 02 Chimica Bruni 04 Chimica Verdi Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 12

studenti Matricola Cognome Nome Data di nascita 6554 Rossi Mario 05/12/1978 8765 Neri Paolo 03/11/1976 9283 Verdi Luisa 12/11/1979 3456 Rossi Maria 01/02/1978 esami Studente Voto Corso 30 24 28 26 corsi Codice Titolo Docente 01 Analisi Mario 02 Chimica Bruni 04 Chimica Verdi Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 13

Vantaggi della struttura basata su valori indipendenza dalle strutture fisiche, che possono cambiare anche dinamicamente si rappresenta solo ciò che è rilevante dal punto di vista dell applicazione (dell utente); i puntatori sono meno comprensibili per l utente finale (senza, l utente finale vede gli stessi dati dei programmatori) i dati sono portabili più facilmente da un sistema ad un altro i valori consentono bi-direzionalità, i puntatori sono direzionali Nota: i puntatori possono essere usati a livello fisico Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 14

Definizioni Schema di relazione: un nome di relazione R con un insieme di attributi A 1,..., A n R(A 1,..., A n ) Schema di base di dati: insieme di schemi di relazione con nomi diversi: R = {R 1 (X 1 ),..., R n (X n )} (Istanza di) relazione su uno schema R(X): insieme r di ennuple su X (Istanza di) base di dati su uno schema R= {R 1 (X 1 ),..., R n (X n )}: insieme di relazioni r = {r 1,..., r n } (con r i relazione su R i ) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 15

Esempio studenti Matricola Cognome Nome Data di nascita 6554 Rossi Mario 05/12/1978 8765 Neri Paolo 03/11/1976 9283 Verdi Luisa 12/11/1979 3456 Rossi Maria 01/02/1978 studenti lavoratori Matricola 6554 3456 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 16

Informazione incompleta ll modello relazionale impone ai dati una struttura rigida: le informazioni sono rappresentate per mezzo di ennuple le ennuple ammesse sono dettate dagli schemi di relazione I dati disponibili possono non corrispondere esattamente al formato previsto, per varie ragioni. Esempio: di Firenze non conosciamo l'indirizzo della prefettura Tivoli non è provincia: non ha prefettura Prato è nuova provincia: ha la prefettura? Città Roma Prefettura Via IV Novembre Firenze Tivoli Prato Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 17

Informazione incompleta: soluzioni? Non conviene (anche se spesso si fa) utilizzare valori ordinari del dominio (0, stringa nulla, 99, etc), per vari motivi: potrebbero non esistere valori non utilizzati valori non utilizzati potrebbero diventare significativi in fase di utilizzo (ad esempio, nei programmi) sarebbe necessario ogni volta tener conto del significato di questi valori Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 18

Informazione incompleta nel modello relazionale Si adotta una tecnica rudimentale ma efficace: valore nullo: denota l assenza di un valore del dominio (e non è un valore del dominio) Formalmente, è sufficiente estendere il concetto di ennupla: t[a], per ogni attributo A, è un valore del dominio dom(a) oppure il valore nullo NULL Si possono (e debbono) imporre restrizioni sulla presenza di valori nulli Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 19

Tipi di interpretazione del valore nullo (almeno) tre casi differenti valore sconosciuto: esiste un valore del dominio, ma non è noto (Firenze) valore inesistente: non esiste un valore del dominio (Tivoli) valore senza informazione: non è noto se esista o meno un valore del dominio (Prato) I DBMS non distinguono i tipi di valore nullo (e quindi implicitamente adottano l interpretazione senza informazione ) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 20

Vincoli di integrità Esistono istanze di basi di dati che, pur sintatticamente corrette, non rappresentano informazioni possibili per l applicazione di interesse. Studenti Esami Corsi Matricola Cognome Nome Nascita 276545 Rossi Maria 23/04/1968 276545 Neri Anna 23/04/1972 788854 Verdi Fabio 12/02/1972 Studente Voto Lode Corso 276545 28 e lode 01 276545 32 02 788854 23 03 200768 30 e lode 03 Codice Titolo Docente 01 Analisi Giani 03 NULL NULL 02 Chimica Belli Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 21

Vincolo di integrità Definizione proprietà che deve essere soddisfatta dalle istanze che rappresentano informazioni corrette per l applicazione ogni vincolo può essere visto come una funzione booleana (o un predicato) che associa ad ogni istanza il valore vero o falso Ad uno schema associamo un insieme di vincoli e consideriamo corrette (lecite, valide, ammissibili) solo le istanze che soddisfano tutti i vincoli Tipi di vincoli: intrarelazionali interrelazionali Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 22

Vincoli di integrità: motivazioni risultano utili al fine di descrivere la realtà di interesse in modo più accurato di quanto le strutture permettano; forniscono un contributo verso la qualità dei dati costituiscono uno strumento di ausilio alla progettazione sono utilizzati dal sistema nella scelta della strategia di esecuzione delle interrogazioni Nota: non tutte le proprietà di interesse sono rappresentabili per mezzo di vincoli esprimibili direttamente Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 23

Vincoli intrarelazionali: vincoli di ennupla Esprimono condizioni sui valori di ciascuna ennupla, indipendentemente dalle altre ennuple. Una possibile sintassi: espressione booleana (con AND, OR e NOT) di atomi che confrontano valori di attributo o espressioni aritmetiche su di essi. Un vincolo di ennupla è un vincolo di dominio se coinvolge un solo attributo Esempi: (Voto 18) AND (Voto 30) (Voto = 30) OR NOT (Lode = e lode ) Lordo = (Ritenute + Netto) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 24

Vincoli intrarelazionali: vincoli di chiave Matricola Cognome Nome Corso Nascita 27655 Rossi Mario Ing Inf 5/12/78 78763 Rossi Mario Ing Inf 3/11/76 65432 Neri Piero Ing Mecc 10/7/79 87654 Neri Mario Ing Inf 3/11/76 67653 Rossi Piero Ing Mecc 5/12/78 il numero di matricola identifica gli studenti: non ci sono due ennuple con lo stesso valore sull attributo Matricola i dati anagrafici identificano gli studenti: non ci sono due ennuple uguali su tutti e tre gli attributi Cognome, Nome e Nascita Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 25

Vincoli di chiave Chiave: insieme di attributi che identificano univocamente le ennuple di una relazione Più precisamente: un insieme K di attributi è superchiave per una relazione r se r non contiene due ennuple distinte t 1 e t 2 tali che t 1 [K] = t 2 [K] K è chiave per r se è una superchiave minimale (cioè non contiene un altra superchiave) per r Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 26

Vincoli di chiave: esempi Matricola Cognome Nome Corso Nascita 27655 Rossi Mario Ing Inf 5/12/78 78763 Rossi Mario Ing Inf 3/11/76 65432 Neri Piero Ing Mecc 10/7/79 87654 Neri Mario Ing Inf 3/11/76 67653 Rossi Piero Ing Mecc 5/12/78 Matricola è una chiave: Matricola è superchiave contiene un solo attributo e quindi è minimale Cognome, Nome, Nascita è un altra chiave: l insieme Cognome, Nome, Nascita è superchiave nessuno dei suoi sottoinsiemi è superchiave Cognome, Nome, Nascita, Corso è superchiave (non chiave) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 27

Un altra chiave? Matricola Cognome Nome Corso Nascita 27655 Rossi Mario Ing Inf 5/12/78 78763 Rossi Mario Ing Civile 3/11/76 65432 Neri Piero Ing Mecc 10/7/79 87654 Neri Mario Ing Inf 3/11/76 67653 Rossi Piero Ing Mecc 5/12/78 non ci sono ennuple uguali su Cognome e Corso: Cognome e Corso formano una chiave ma è sempre vero? Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 28

Vincoli, schemi e istanze i vincoli corrispondono a proprietà del mondo reale modellato dalla base di dati interessano a livello di schema (con riferimento cioè a tutte le istanze): ad uno schema associamo un insieme di vincoli che vogliamo siano soddisfatti da tutte le sue istanze corrette consideriamo quindi corrette (valide, ammissibili) le istanze che soddisfano tutti i vincoli N.B.: un'istanza può soddisfare altri vincoli ( per caso ) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 29

Individuazione delle chiavi Individuiamo le chiavi considerando le proprietà che i dati soddisfano nell applicazione (il frammento di mondo reale di interesse ); notando quali insiemi di attributi permettono di identificare univocamente le ennuple; e individuando i sottoinsiemi minimali di tali insiemi che conservano la capacità di identificare le ennuple. Esempio: Studenti(Matricola, Cognome, Nome, Corso, Nascita) ha 2 chiavi: Matricola Cognome, Nome, Nascita Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 30

Esistenza delle chiavi poiché le relazioni sono insiemi, una relazione non può contenere ennuple uguali fra loro: ogni relazione ha come superchiave l insieme degli attributi su cui è definita poiché l insieme di tutti gli attributi è una superchiave per ogni relazione, ogni schema di relazione ha almeno una superchiave ne segue che ogni schema di relazione ha (almeno) una chiave Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 31

Importanza delle chiavi l esistenza delle chiavi garantisce l accessibilità a ciascun dato della base di dati ogni singolo valore è univocamente accessibile tramite: nome della relazione valore della chiave nome dell attributo le chiavi sono lo strumento principale attraverso il quale vengono correlati i dati in relazioni diverse ( il modello relazionale è basato su valori ) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 32

Chiavi e valori nulli In presenza di valori nulli, i valori degli attributi che formano la chiave: non permettono di identificare le ennuple come desiderato né permettono di realizzare facilmente i riferimenti da altre relazioni Matricola Cognome Nome Corso Nascita NULL NULL Mario Ing Inf 5/12/78 78763 Rossi Mario Ing Civile 3/11/76 65432 Neri Piero Ing Mecc 10/7/79 87654 Neri Mario Ing Inf NULL NULL Neri Mario NULL 5/12/78 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 33

Chiave primaria La presenza di valori nulli nelle chiavi deve essere limitata. Soluzione pratica: per ogni relazione scegliamo una chiave (la chiave primaria) su cui non ammettiamo valori nulli. Notazione per la chiave primaria: gli attributi che la compongono sono sottolineati Matricola Cognome Nome Corso Nascita 27655 Rossi Mario Ing Inf 5/12/78 78763 Rossi Mario Ing Civile 3/11/76 65432 Neri Piero Ing Mecc 10/7/79 87654 Neri Mario Ing Inf NULL 67653 Rossi Piero NULL 5/12/78 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 34

Vincoli interrelazionali: integrità referenziale Informazioni in relazioni diverse sono correlate attraverso valori comuni, in particolare, attraverso valori delle chiavi (primarie, di solito). Un vincolo di integrità referenziale (detto anche vincolo di ( foreign key ) fra un insieme di attributi X di una relazione R 1 e un altra relazione R 2 impone ai valori su X di ciascuna ennupla dell istanza di R 1 di comparire come valori della chiave (primaria) dell istanza di R 2. Giocano un ruolo fondamentale nel concetto di modello basato su valori. Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 35

Vincoli di integrità referenziale: esempio Infrazioni Codice Data Vigile Prov Numero 34321 1/2/95 3987 MI 39548K 53524 4/3/95 3295 TO E39548 64521 5/4/96 3295 PR 839548 73321 5/2/98 9345 PR 839548 Vigili Matricola Cognome Nome 3987 Rossi Luca 3295 Neri Piero 9345 Neri Mario 7543 Mori Gino Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 36

Infrazioni Esempio (cont.) Codice Data Vigile Prov Numero 34321 1/2/95 3987 MI 39548K 53524 4/3/95 3295 TO E39548 64521 5/4/96 3295 PR 839548 73321 5/2/98 9345 PR 839548 Auto Prov Numero Cognome Nome MI 39548K Rossi Mario TO E39548 Rossi Mario PR 839548 Neri Luca Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 37

Vincoli di integrità referenziale: esempio Nell esempio, i vincoli di integrità referenziale sussistono fra: l attributo Vigile della relazione Infrazioni e la relazione Vigili gli attributi Prov e Numero di Infrazioni e la relazione Auto Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 38

Violazione di vincolo di integrità referenziale Infrazioni Codice Data Vigile Prov Numero 34321 1/2/95 3987 MI 39548K 53524 4/3/95 3295 TO E39548 64521 5/4/96 2468 PR 839548 73321 5/2/98 9345 PR 839548 Vigili Matricola Cognome Nome 3987 Rossi Luca 3295 Neri Piero 9345 Neri Mario 7543 Mori Gino Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 39

Violazione di vincolo di integrità ref. (cont.) Infrazioni Codice Data Vigile Prov Numero 34321 1/2/95 3987 MI 39548K 53524 4/3/95 3295 TO 39548K 64521 5/4/96 3295 PR 839548 73321 5/2/98 9345 PR 839548 Auto Prov Numero Cognome Nome MI 39548K Rossi Mario TO E39548 Rossi Mario PR 839548 Neri Luca Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 40

Integrità referenziale e valori nulli In presenza di valori nulli i vincoli possono essere resi meno restrittivi. Impiegati Matricola Cognome Progetto 34321 Rossi IDEA 53524 Neri XYZ 64521 Verdi NULL 73032 Bianchi IDEA Progetti Codice Inizio Durata Costo IDEA 01/2000 36 200 XYZ 07/2001 24 120 BOH 09/2001 24 150 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 41

Integrità referenziale: azioni compensative Sono possibili meccanismi per il supporto alla gestione dei vincoli di integrità ("azioni" compensative a seguito di violazioni) Ad esempio, se viene eliminata una ennupla causando una violazione: comportamento standard : rifiuto dell'operazione azioni compensative: eliminazione in cascata introduzione di valori nulli Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 42

Eliminazione in cascata Impiegati Matricola Cognome Progetto 34321 Rossi IDEA 53524 Neri XYZ 64521 Verdi NULL 73032 Bianchi IDEA Progetti Codice Inizio Durata Costo IDEA 01/2000 36 200 XYZ 07/2001 24 120 BOH 09/2001 24 150 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 43

Introduzione di valori nulli Impiegati Matricola Cognome Progetto 34321 Rossi IDEA 53524 Neri NULL 64521 Verdi NULL 73032 Bianchi IDEA Progetti Codice Inizio Durata Costo IDEA 01/2000 36 200 XYZ 07/2001 24 120 BOH 09/2001 24 150 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 44

Vincoli multipli su più attributi Incidenti Codice Data ProvA NumeroA ProvB NumeroB 34321 1/2/95 TO E39548 MI 39548K 64521 5/4/96 PR 839548 TO E39548 Auto Prov Numero Cognome Nome MI 39548K Rossi Mario TO E39548 Rossi Mario PR 839548 Neri Luca Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 45

2. Il modello relazionale 2.2 Algebra relazionale 1. basi di dati relazionali 2. algebra relazionale Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 46

Linguaggi per basi di dati operazioni sullo schema: DDL: data definition language operazioni sui dati: DML: data manipulation language interrogazione ("query") aggiornamento Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 47

Tipologia: Linguaggi di interrogazione per basi di dati relazionali Dichiarativi: specificano le proprietà del risultato ("che cosa") Procedurali: specificano le modalità di generazione del risultato ("come") Rappresentanti più significativi: Algebra relazionale: procedurale Calcolo relazionale: dichiarativo (teorico) SQL (Structured Query Language): parzialmente dichiarativo (reale) QBE (Query by Example): dichiarativo (reale) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 48

Algebra relazionale Costitutita da un insieme di operatori definiti su relazioni che producono relazioni e possono essere composti Operatori dell algebra relazionale: unione, intersezione, differenza ridenominazione selezione proiezione join (join naturale, prodotto cartesiano, theta-join) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 49

Operatori insiemistici le relazioni sono insiemi i risultati debbono essere relazioni è possibile applicare unione, intersezione, differenza solo a relazioni definite sugli stessi attributi Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 50

Unione Laureati Matricola 7274 Nome Rossi Età 42 7432 9824 Neri Verdi 54 45 Laureati Quadri Quadri Matricola 9297 7432 9824 Matricola Nome Età 7274 Rossi 42 7432 Neri 54 9824 Verdi 45 9297 Neri 33 Nome Neri Neri Verdi Età 33 54 45 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 51

Intersezione Laureati Matricola 7274 Nome Rossi Età 42 7432 9824 Neri Verdi 54 45 Quadri Matricola 9297 Nome Neri Età 33 7432 9824 Neri Verdi 54 45 Laureati Quadri Matricola Nome Età 7432 Neri 54 9824 Verdi 45 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 52

Differenza Laureati Matricola Nome Età 7274 Rossi 42 7432 Neri 54 9824 Verdi 45 Laureati Quadri Quadri Matricola 9297 7432 9824 Matricola Nome Età 7274 Rossi 42 7432 Neri 54 9824 Verdi 45 Nome Neri Neri Verdi Età 33 54 45 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 53

Un unione sensata ma impossibile Paternità Maternità Padre Adamo Adamo Abramo Figlio Abele Caino Isacco Madre Eva Eva Sara Figlio Abele Set Isacco Paternità Maternità?? Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 54

Ridenominazione operatore monadico (con un argomento) "modifica lo schema" lasciando inalterata l'istanza dell'operando Paternità REN Genitore Padre (Paternità) Padre Figlio Genitore Padre Figlio Adamo Abele Adamo Abele Adamo Caino Adamo Caino Abramo Isacco Abramo Isacco Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 55

Paternità Padre Adamo Adamo Abramo Figlio Abele Caino Isacco REN Genitore Padre (Paternità) Genitore Figlio Adamo Abele Adamo Caino Abramo Isacco Maternità Madre Eva Eva Sara Figlio Abele Set Isacco REN Genitore Madre (Maternità) Genitore Figlio Eva Abele Eva Set Sara Isacco Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 56

REN Genitore Padre (Paternità) Genitore Figlio Adamo Abele Adamo Caino Abramo Isacco REN Genitore Genitore Figlio Eva Abele Eva Set Sara Isacco Madre (Maternità) REN Genitore Padre (Paternità) REN Genitore Madre (Maternità) Genitore Figlio Adamo Abele Adamo Caino Abramo Isacco Eva Abele Eva Set Sara Isacco Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 57

Impiegati Cognome Rossi Neri Ufficio Roma Milano Stipendio 55 64 Operai Cognome Bruni Verdi Fabbrica Monza Latina Salario 45 55 REN Sede, Retribuzione Ufficio, Stipendio (Impiegati) REN Sede, Retribuzione Fabbrica, Salario (Operai) Cognome Sede Retribuzione Rossi Roma 55 Neri Milano 64 Bruni Monza 45 Verdi Latina 55 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 58

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 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 59

Impiegati Matricola Cognome Filiale Stipendio 7309 Rossi Roma 55 5998 Neri Milano 64 9553 Milano Milano 44 5698 Neri Napoli 64 impiegati che guadagnano più di 50 guadagnano più di 50 e lavorano a Milano hanno lo stesso nome della filiale presso cui lavorano Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 60

Selezione, sintassi e semantica Sintassi: SEL Condizione (Operando) Condizione: espressione booleana (come quelle dei vincoli di ennupla) Semantica il risultato contiene le ennuple dell'operando che soddisfano la condizione Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 61

impiegati che guadagnano più di 50 Impiegati Matricola Cognome Filiale Stipendio 7309 Rossi Roma 55 5998 Neri Milano 64 9553 5698 Milano Neri Milano Napoli 44 64 5698 Neri Napoli 64 SEL Stipendio > 50 (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 62

impiegati che guadagnano più di 50 e lavorano a Milano Impiegati Matricola 7309 5998 5998 9553 5698 Cognome Filiale Stipendio Rossi Neri Milano Roma 55 64 Neri Milano 64 Milano Milano 44 Neri Napoli 64 SEL Stipendio > 50 AND Filiale = 'Milano' (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 63

impiegati che hanno lo stesso nome della filiale presso cui lavorano Impiegati Matricola Cognome Filiale Stipendio 7309 9553 Milano Rossi Milano Roma 55 44 5998 Neri Milano 64 9553 Milano Milano 44 5698 Neri Napoli 64 SEL Cognome = Filiale (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 64

Selezione e proiezione Sono due operatori "ortogonali" selezione: decomposizione orizzontale proiezione: decomposizione verticale selezione proiezione Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 65

Proiezione operatore monadico produce un risultato che ha parte degli attributi dell'operando contiene ennuple cui contribuiscono tutte le ennuple dell'operando Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 66

Impiegati Matricola Cognome Filiale Stipendio 7309 Neri Napoli 55 5998 Neri Milano 64 9553 Rossi Roma 44 5698 Rossi Roma 64 per tutti gli impiegati: matricola e cognome cognome e filiale Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 67

Proiezione, sintassi e semantica Sintassi PROJ ListaAttributi (Operando) Semantica il risultato contiene le ennuple ottenute da tutte le ennuple dell'operando ristrette agli attributi nella lista Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 68

matricola e cognome di tutti gli impiegati Matricola 7309 5998 9553 5698 Cognome Filiale Stipendio Neri Napoli 55 Neri Milano 64 Rossi Roma 44 Rossi Roma 64 PROJ Matricola, Cognome (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 69

cognome e filiale di tutti gli impiegati Matricola 7309 5998 9553 5698 Cognome Filiale Stipendio Neri Napoli 55 Neri Milano 64 Rossi Roma 44 Rossi Roma 64 PROJ Cognome, Filiale (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 70

Cardinalità delle proiezioni una proiezione contiene al più tante ennuple quante l'operando può contenerne di meno se X è una superchiave di R, allora PROJ X (R) contiene esattamente tante ennuple quante R Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 71

Selezione e proiezione Combinando selezione e proiezione, possiamo estrarre interessanti informazioni da una relazione matricola e cognome degli impiegati che guadagnano più di 50 Matricola Cognome Filiale Stipendio 7309 Rossi Roma 55 5998 Neri Milano 64 9553 5698 Milano Neri Milano Napoli 44 64 5698 Neri Napoli 64 PROJ Matricola,Cognome ( SEL Stipendio > 50 (Impiegati)) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 72

Join combinando selezione e proiezione, possiamo estrarre informazioni da una relazione non possiamo però correlare informazioni presenti in relazioni diverse il join è l'operatore più interessante dell'algebra relazionale permette di correlare dati in relazioni diverse Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 73

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 1 25 2 13 3 27 4 28 Mario Rossi Nicola Russo Mario Bianchi Remo Neri 1 Mario Rossi 2 Nicola Russo 3 Mario Bianchi 4 Remo Neri 25 13 27 28 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 74

Numero Voto 1 25 2 13 3 27 4 28 Numero Candidato 1 Mario Rossi 2 Nicola Russo 3 Mario Bianchi 4 Remo Neri Numero 1 2 3 4 Candidato Mario Rossi Nicola Russo Mario Bianchi Remo Neri Voto 25 13 27 28 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 75

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 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 76

Join, sintassi e semantica R 1 (X 1 ), R 2 (X 2 ) R 1 JOIN R 2 è una relazione su X 1 X 2 { t su X 1 X 2 esistono t 1 R 1 e t 2 R 2 con t[x 1 ]=t 1 e t[x 2 ] =t 2 } Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 77

Un join completo Impiegato Reparto Reparto Capo Rossi A A Mori Neri B B Bruni Bianchi B Impiegato Reparto Capo Rossi A Mori Neri B Bruni Bianchi B Bruni In un join completo ogni ennupla contribuisce al risultato. Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 78

Un join non completo Impiegato Reparto Rossi A Neri B Bianchi B Reparto B C Capo Mori Bruni Impiegato Reparto Capo Neri B Mori Bianchi B Mori Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 79

Un join vuoto Impiegato Reparto Rossi A Neri B Bianchi B Reparto D C Capo Mori Bruni Impiegato Reparto Capo Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 80

Un join completo, con n x m ennuple Impiegato Reparto Rossi AB Neri B Reparto AB B Capo Mori Bruni Impiegato Reparto Capo Rossi B Mori Rossi B Bruni Neri B Mori Bianchi B Bruni Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 81

R 1 (A,B), R 2 (B,C) Cardinalità del join In generale, il join di R 1 e R 2 contiene un numero di ennuple compreso fra zero e il prodotto di R 1 e R 2 : 0 R 1 JOIN R 2 R 1 R 2 se il join coinvolge una chiave di R 2 (ovvero, B è chiave in R 2 ), allora il numero di ennuple è compreso fra zero e R 1 : 0 R 1 JOIN R 2 R 1 se il join coinvolge una chiave di R 2 (ovvero, B è chiave in R 2 ) ed esiste un vincolo di integrità referenziale fra B (in R 1 ) e R 2, allora il numero di ennuple è pari a R 1 : R 1 JOIN R 2 = R 1 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 82

Join, un osservazione Impiegato Reparto Rossi A Neri B Bianchi B Reparto B C Capo Mori Bruni Impiegato Reparto Capo Neri B Mori Bianchi B Mori Alcune ennuple non contribuiscono al risultato: vengono "tagliate fuori" Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 83

Join esterno Il join esterno estende, con valori nulli, le ennuple che verrebbero tagliate fuori da un join (interno) esiste in tre versioni: sinistro: mantiene tutte le ennuple del primo operando, estendendole con valori nulli, se necessario destro:... del secondo operando... completo: di entrambi gli operandi... Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 84

Join esterno sinistro Impiegati Impiegato Reparto Rossi A Neri B Bianchi B Reparti Reparto B C Capo Mori Bruni Impiegati JOIN LEFT Reparti Impiegato Reparto Capo Neri B Mori Bianchi B Mori Rossi A NULL Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 85

Join esterno destro Impiegati Impiegato Reparto Rossi A Neri B Bianchi B Reparti Reparto B C Capo Mori Bruni Impiegati JOIN RIGHT Reparti Impiegato Reparto Capo Neri B Mori Bianchi B Mori NULL C Bruni Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 86

Join esterno completo Impiegati Reparti Impiegato Reparto Reparto Rossi A B Neri B C Bianchi B Impiegati JOIN FULL Reparti Impiegato Reparto Capo Neri B Mori Bianchi B Mori Rossi A NULL NULL C Bruni Capo Mori Bruni Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 87

Join e proiezioni Impiegato Reparto Rossi A Neri B Bianchi B Reparto B C Capo Mori Bruni Impiegato Reparto Capo Neri B Mori Bianchi B Mori Impiegato Reparto Neri B Bianchi B Reparto B Capo Mori Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 88

Impiegato Neri Bianchi Verdi Proiezioni e join Impiegato Reparto Capo Neri B Mori Bianchi B Bruni Verdi A Bini Reparto B B A Reparto B B A Impiegato Reparto Capo Neri B Mori Bianchi B Bruni Neri B Bruni Bianchi B Mori Verdi A Bini Capo Mori Bruni Bini Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 89

Join e proiezioni R 1 (X 1 ), R 2 (X 2 ) PROJ X1 (R 1 JOIN R 2 ) R 1 R(X), X = X 1 X 2 (PROJ X1 (R)) JOIN (PROJ X2 (R)) R Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 90

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 ) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 91

Impiegati Impiegato Reparto Rossi A Neri B Bianchi B Impiegati JOIN Reparti Reparti Codice A B Capo Mori Bruni Impiegato Reparto Codice Capo Rossi A A Mori Rossi A B Bruni Neri B A Mori Neri B B Bruni Bianchi B A Mori Bianchi B B Bruni Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 92

Theta-join Il prodotto cartesiano, in pratica, ha senso (quasi) solo se seguito da selezione: SEL Condizione (R 1 JOIN R 2 ) L'operazione viene chiamata theta-join e indicata con R 1 JOIN Condizione R 2 La condizione di selezione è spesso una congiunzione (AND) di atomi di confronto A 1 ϑ A 2 dove ϑ è uno degli operatori di confronto (=, >, <, ). Da questo deriva il nome theta-join. Se l'operatore è sempre l'uguaglianza (=) allora si parla di equi-join. Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 93

Impiegati Impiegato Reparto Rossi A Neri B Bianchi B Reparti Codice A B Capo Mori Bruni Impiegati JOIN Reparto=Codice Reparti Impiegato Reparto Codice Capo Rossi A A Mori Rossi Neri AB B Bruni Bianchi Neri B AB Bruni Mori Neri B B Bruni Bianchi B A Mori Bianchi B B Bruni Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 94

Impiegati Impiegato Reparto Rossi A Neri B Bianchi B Reparti Reparto A B Capo Mori Bruni Impiegati JOIN Reparti Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 95

Join naturale ed equi-join Possiamo riesprimere un join naturale usando un equi-join. Impiegati Reparti Impiegato Reparto Reparto Capo Impiegati JOIN Reparti PROJ Impiegato,Reparto,Capo ( SEL Reparto=Codice ( Impiegati JOIN REN Codice Reparto (Reparti) )) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 96

Esempi Impiegati Matricola Nome Età Stipendio 7309 Rossi 34 45 5998 Bianchi 37 38 9553 Neri 42 35 5698 Bruni 43 42 4076 Mori 45 50 8123 Lupi 46 60 Supervisione Impiegato 7309 5998 9553 5698 4076 Capo 5698 5698 4076 4076 8123 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 97

Trovare matricola, nome, età e stipendio degli impiegati che guadagnano più di 40 milioni. SEL Stipendio>40 (Impiegati) Matricola 7309 5998 5698 9553 4076 5698 8123 4076 8123 Nome Età Stipendio Rossi 34 45 Bianchi Bruni 37 43 38 42 Mori Neri 42 45 35 50 Bruni Lupi 43 46 42 60 Mori 45 50 Lupi 46 60 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 98

Trovare matricola, nome ed età degli impiegati che guadagnano più di 40 milioni. PROJ Matricola, Nome, Età ( SEL Stipendio>40 (Impiegati) ) Matricola 7309 5998 5698 9553 4076 5698 8123 4076 8123 Nome Età Stipendio Rossi 34 45 Bianchi Bruni 37 43 38 42 Mori Neri 42 45 35 50 Bruni Lupi 43 46 42 60 Mori 45 50 Lupi 46 60 Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 99

Trovare le matricole dei capi degli impiegati che guadagnano più di 40 milioni. Impiegati Matricola Nome Età Stipendio Supervisione Impiegato Capo PROJ Capo (Supervisione JOIN Impiegato=Matricola (SEL Stipendio>40 (Impiegati))) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 100

Trovare nome e stipendio dei capi degli impiegati che guadagnano più di 40 milioni. Impiegati Matricola Nome Età Stipendio Supervisione Impiegato Capo PROJ Nome,Stipendio ( Impiegati JOIN Matricola=Capo PROJ Capo (Supervisione JOIN Impiegato=Matricola (SEL Stipendio>40 (Impiegati)))) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 101

Trovare gli impiegati che guadagnano più del proprio capo, mostrando matricola, nome e stipendio dell'impiegato e del capo. Impiegati Matricola Nome Età Stipendio Supervisione Impiegato Capo PROJ Matr,Nome,Stip,MatrC,NomeC,StipC (SEL Stipendio>StipC ( REN MatrC,NomeC,StipC,EtàC Matr,Nome,Stip,Età (Impiegati) JOIN MatrC=Capo (Supervisione JOIN Impiegato=Matricola Impiegati))) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 102

Trovare le matricole dei capi i cui impiegati guadagnano tutti più di 40 milioni. Impiegati Matricola Nome Età Stipendio Supervisione Impiegato Capo PROJ Capo (Supervisione) - PROJ Capo (Supervisione JOIN Impiegato=Matricola (SEL Stipendio 40 (Impiegati))) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 103

Equivalenza di espressioni Due espressioni sono equivalenti se producono lo stesso risultato qualunque sia l'istanza attuale della base di dati L'equivalenza è importante in pratica perché i DBMS cercano di eseguire espressioni equivalenti a quelle date, ma meno "costose" Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 104

Un'equivalenza importante Effettuare le selezioni il prima possibile (push selections) Esempio: se A è attributo di R 1 SEL A=10 (R 1 JOIN R 2 ) = R 1 JOIN SEL A=10 ( R 2 ) Le selezioni tipicamente riducono in modo significativo la dimensione del risultato intermedio (e quindi il costo dell'operazione). Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 105

Selezione con valori nulli Impiegati Matricola Cognome Filiale Età 7309 Rossi Roma 32 5998 Neri Milano 45 9553 Bruni Milano NULL SEL Età > 40 (Impiegati) La condizione atomica è vera solo per valori non nulli. Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 106

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! Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 107

Selezione con valori nulli: soluzione SEL Età > 40 (Impiegati) la condizione atomica è vera solo per valori non nulli per riferirsi ai valori nulli esistono forme apposite di condizioni: IS NULL IS NOT NULL si potrebbe usare (ma non serve) una "logica a tre valori" (vero, falso, sconosciuto) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 108

Quindi: SEL Età>30 (Persone) SEL Età 30 (Persone) SEL Età IS NULL (Persone) = SEL Età>30 Età 30 Età IS NULL (Persone) = Persone Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 109

Impiegati Matricola Cognome Filiale Età 7309 5998 Rossi Neri Milano Roma 32 45 5998 9553 Bruni Neri Milano NULL 45 9553 Bruni Milano NULL SEL (Età > 40) OR (Età IS NULL) (Impiegati) Diego Calvanese Basi di Dati A.A. 2003/2004 2. Modello relazionale - 110