Basi di dati. SQL: concetti base



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

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

Basi di Dati. Programmazione e gestione di sistemi telematici

Definizione di domini

SQL Laboratorio di Basi di Dati a.a. 2002/2003

Corso di Laurea in Ingegneria Informatica Algoritmi e basi di dati Modulo Basi di dati a.a

SQL: "storia" 31/05/2006 2

Capitolo 4: SQL (Slides( da Atzeni,, Ceri, Paraboschi, Torlonee,, Basi di dati McGraw-Hill. Hill,, 2002)

Basi di Dati. 3. Il Linguaggio SQL. Basi di Dati - A.A. 2003/ Diego Calvanese 3. SQL - 1. Diego Calvanese SQL SQL-92

Basi di dati. Il Linguaggio SQL. K. Donno - Il Linguaggio SQL

Basi di dati. SQL: concetti base

SQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)

1.3 Il linguaggio SQL

Basi di Dati. Laboratorio Ing. G. Laboccetta Dott.ssa. V. Policicchio. Corso di Laurea in Informatica. a.a

SQL (STRUCTURED QUERY LANGUAGE)

Il linguaggio SQL. è di fatto lo standard tra i linguaggi per la gestione di data base relazionali.

SQL SQL. Definizione dei dati. Domini. Esistono 6 domini elementari:

DDL, VINCOLI D INTEGRITÁ, AGGIORNAMENTI E VISTE. SQL è più di un semplice linguaggio di interrogazione

Storia. Corso di Basi di Dati Spaziali. Componente DDL. Funzionalità. Esempio. Creazione di schema. Linguaggi: SQL. Storia:

Esercitazione query in SQL L esercitazione viene effettuata sul database viaggi e vacanze che prevede il seguente modello E/R:

SQL. SQL: una visione panoramica. SQL: "storia" Definizione dei dati

Documentazione SQL. Argomento Sintassi Note Definizione schema create schema [NomeSchema] [[authorization] Autorizzazione] {DefElementoSchema}

Basi di Dati: Corso di laboratorio

SQL Sintassi Dei Comandi

Basi di dati Maurizio Lenzerini Dipartimento di Informatica e Sistemistica Antonio Ruberti Università di Roma La Sapienza

Operazioni sui database

Interrogazioni nidificate, commenti

OR true null false true true true true null true null null false true null false NOT

Join in SQL (primo modo) Informatica. Tabella Dipartimento. Interrogazione 4a. Interrogazione 4b. Interrogazione 4a

Il linguaggio SQL: query innestate

Basi di Dati Relazionali

Join esplicito. SELECT con join esplicito, sintassi. Ulteriore estensione: join naturale (meno diffuso) Outer join. Join esterno: "outer join"

Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL

DBMS (Data Base Management System)

SQL /10/2016 Basi di dati - SQL 1

SQL-DDL. Basi di Dati. Prof. Alfredo Cuzzocrea Università degli Studi di Trieste

Istruzioni DML di SQL

Il linguaggio SQL: le basi

Gestione delle tabelle

Il linguaggio SQL. Il linguaggio SQL. Il linguaggio SQL. SQL - Tipi di dato. SQL - Tipi di dato numerici. SQL - Tipi di dato numerici

SQL - Tipi di dato Il linguaggio SQL


Domini elementari, 2. Basi di dati. Domini elementari, 4. Domini elementari, 3. Domini definiti dagli utenti. Domini elementari, 5

Basi di dati SQL. Standardizzazione di SQL. Linguaggi di Interrogazione: SQL. Prof.Angela Bonifati

SQL Esempi. 24/10-7/11/2016 Basi di dati - SQL 1

Uso delle variabili di alias. SQL slide aggiuntive. Interrogazione 25. Interrogazione 26

Linguaggio SQL: fondamenti D B M G. Gestione delle tabelle

SQL IL LINGUAGGIO DI INTERROGAZIONE

Informatica. Sintassi. Interrogazioni in SQL. Significato dell interrogazione. Tabella Impiegato. Basi di dati parte 4 SQL

SQL: Concetti Base -Prima Parte-

DDL DML. Tipi di linguaggi per basi di dati. Si distinguono due categorie:

SQL (STRUCTURED QUERY LANGUAGE)

SQL Esempi /10/2017 Basi di dati - SQL 1

MAX, SUM, AVG, COUNT)

Corso di Laurea in Ingegneria Informatica Fondamenti di Informatica II Modulo Basi di dati a.a

Basi di Dati e Sistemi Informativi. Structured Query Language

Corso sul linguaggio SQL

Il linguaggio SQL: le basi. Versione elettronica: SQLa-basi.pdf

Query. Query (Interrogazioni) SQL SQL. Significato dell interrogazione. Sintassi

ESEMPI DI QUERY SQL. Esempi di Query SQL Michele Batocchi AS 2012/2013 Pagina 1 di 7

Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL

Giovanna Rosone 04/03/ /03/2010 SQL, Istruzioni per la modifica dello schema

SQL. Alcune note sulla definizione dei dati

Corso di Informatica (Basi di Dati)

Capitolo 4. Soluzione: Soluzione: Create domain STRING as character varying (256) default sconosciuto not null

SQL prima 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 2011/12

Laboratorio di Basi di Dati e Web

Basi di Dati prof. Letizia Tanca lucidi ispirati al libro Atzeni-Ceri-Paraboschi-Torlone. SQL: il DDL

Linguaggio SQL. Structured Query Language

Operatori aggregati: COUNT

Corso di Laboratorio di Basi di Dati

OSSIF WEB. Manuale query builder

Il linguaggio SQL: viste e tabelle derivate. Versione elettronica: SQLd-viste.pdf

Linguaggio SQL. Prof. Francesco Accarino IIS Altiero Spinelli Sesto San Giovanni

PROGRAMMA DI CLASSE 5AI

Corso di Laurea in Ingegneria Informatica Fondamenti di Informatica II Modulo Basi di dati a.a

Operatori aggregati: COUNT

Archivi e Basi di Dati

Linguaggi per basi di dati

Il linguaggio SQL: viste e tabelle derivate

E. Giunchiglia Basi di dati 1 (trasparenze basate su Atzeni, Ceri, Paraboschi, Torlone: Basi di dati, Capitolo 4) SQL SQL. Definizione dei dati in SQL

SQL. Structured Query Language 1974: SEQUEL by IBM 1981: SQL by IBM : SQL ISO 9075:1992 SQL:1999 SQL:2003

4 SQL : Interrogazioni nidificate

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

Vincoli di Integrità Approccio dichiarativo alla loro implementazione

IL LINGUAGGIO SQL IDENTIFICATORI E TIPI DI DATI COMANDI E ISTRUZIONI

Laboratorio di Basi di Dati

Corso Sistemi Informativi Avanzati. Programma 30 set Installazione Macchina Virtuale. Introduzione alla BI nelle Aziende.

SQL e ACCESS. Modello relazionale PROBLEMA ENTITA STUDENTE

Il linguaggio SQL: DDL di base

Corso sul linguaggio SQL

Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL. Definizione dei dati in SQL. SQL: "storia" Domini. CREATE TABLE, esempio

SQL. Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL. Definizione dei dati in SQL. SQL: "storia" Domini

CAPITOLO 4 ESERCIZI SU SQL

Basi di dati e Sistemi informativi aziendali

SQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)

SQL. Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL. Definizione dei dati in SQL. SQL: "storia" Domini

INDICI. Prevediamo di effettuare spesso interrogazioni simili alle seguenti:

Corso di Basi di Dati A.A. 2013/2014

Transcript:

Basi di dati SQL: concetti base

SQL originariamente "Structured Query Language", ora "nome proprio" linguaggio con varie funzionalità: contiene sia il DDL sia il DML ne esistono varie versioni vediamo gli aspetti essenziali, non i dettagli 2

SQL: "storia" prima proposta SEQUEL (1974); prime implementazioni in SQL/DS e Oracle (1981) dal 1983 ca. "standard di fatto" standard (1986, poi 1989, 1992, 1999, 2003, 2006, 2008, ) recepito solo in parte (!! Vedi http://troels.arvin.dk/db/rdbms/ per un confronto) 3

Evoluzione dello standard: SQL-base SQL-86: primo standard. Possedeva gran parte delle primitive per la formulazione di interrogazioni, ma offriva un supporto limitato per la definizione e manipolazione degli schemi e delle istanze SQL-89: aggiunge la definizione di integrità referenziale 4

Evoluzione dello standard: SQL-2 SQL-92: in gran parte compatibile con la versione precedente, introduce nuove funzionalità: Nuovi costrutti (e.g. coalesce, nullif e case) 3 livelli d implementazione: entry, intermediate, full 5

Evoluzione dello standard: SQL-3 (1) Organizzato in: SQL:1999: introduce l object-relational, trigger e funzioni esterne SQL:2003: estende il modello ad oggetti e introduce l integrazione con Java ed XML 6

Evoluzione dello standard: SQL-3 (2) SQL:2006: estende l integrazione della parte XML ad altri linguaggi (e.g. XQuery) SQL:2008: introduce una serie di lievi modifiche (e.g. supporto trigger con instead of) 7

Evoluzione dello standard SQL Nome Informale Nome Ufficiale Caratteristiche SQL-Base SQL-2 SQL-3 SQL-86 SQL-89 SQL-92 SQL:1999 SQL:2003 SQL:2006 Costrutti di base Integrità referenziale Modello relazionale Vari costrutti nuovi 3 livelli: entry, intermediate, full Modello relazionale ad oggetti Organizzato in diverse parti Trigger, funzioni esterne, Estensioni del modello ad oggetti Eliminazione di costrutti non usati Nuove parti: SQL/JRT, SQL/XML, Estensione della parte XML SQL:2008 Lievi aggiunte (per esempio: trigger instead of)! 8

Definizione dei dati in SQL (1) Istruzione CREATE DATABASE: Crea un nuovo database, che potrà contenere tabelle, viste, trigger o altri tipi di oggetti Esempio: note: CREATE DATABASE Azienda In SQLite sqlite3_open_v2(azienda) In Mimer CREATE DATABANK Azienda 9

Definizione dei dati in SQL (2) Istruzione CREATE SCHEMA: Consente la dichiarazione di uno schema di base di dati come collezione di oggetti, cioè domini, tabelle, viste, privilegi ed asserzioni. Esempio: CREATE SCHEMA schema_azienda 10

Definizione dei dati in SQL (3) Istruzione CREATE SCHEMA: Seguito dal parametro AUTHORIZATION indica il proprietario dello schema. Nel caso in cui venga omesso, il proprietario sarà l utente che ha digitato il comando Esempio: CREATE SCHEMA schema_azienda AUTHORIZATION amministratore 11

Definizione dei dati in SQL (4) Istruzione CREATE TABLE: definisce uno schema di relazione e ne crea un istanza vuota specifica attributi, domini e vincoli 12

CREATE TABLE: esempio CREATE TABLE Impiegato( Matricola CHAR(6) PRIMARY KEY, Nome CHAR(20) NOT NULL, Cognome CHAR(20) NOT NULL, Dipart CHAR(15), Stipendio NUMERIC(9) DEFAULT 0, FOREIGN KEY(Dipart) REFERENCES Dipartimento(NomeDip), UNIQUE (Cognome,Nome) ) 13

Domini Domini elementari (predefiniti) Domini definiti dall'utente (semplici, ma riutilizzabili) 14

Domini elementari Carattere: singoli caratteri o stringhe, anche di lunghezza variabile Numerici, esatti e approssimati Data, ora, intervalli di tempo Introdotti in SQL-3: Boolean BLOB, CLOB (binary/character large object): per grandi immagini e testi 15

Definizione di domini Istruzione CREATE DOMAIN: definisce un dominio (semplice), utilizzabile in definizioni di relazioni, anche con vincoli e valori di default 16

CREATE DOMAIN: esempio CREATE DOMAIN Voto AS SMALLINT DEFAULT NULL CHECK ( value >=18 AND value <= 30 ) 17

Vincoli intrarelazionali NOT NULL UNIQUE definisce chiavi PRIMARY KEY: chiave primaria (una sola, implica NOT NULL; DB2 non rispetta lo standard) CHECK, vedremo più avanti 18

UNIQUE e PRIMARY KEY due forme: nella definzione di un attributo, se forma da solo la chiave come elemento separato 19

CREATE TABLE: esempio CREATE TABLE Impiegato( Matricola CHAR(6) PRIMARY KEY, Nome CHAR(20) NOT NULL, Cognome CHAR(20) NOT NULL, Dipart CHAR(15), Stipendio NUMERIC(9) DEFAULT 0, FOREIGN KEY(Dipart) REFERENCES Dipartimento(NomeDip), UNIQUE (Cognome,Nome) ) 20

PRIMARY KEY, alternative Matricola CHAR(6) PRIMARY KEY Matricola CHAR(6), PRIMARY KEY (Matricola) 21

CREATE TABLE: esempio CREATE TABLE Impiegato( Matricola CHAR(6) PRIMARY KEY, Nome CHAR(20) NOT NULL, Cognome CHAR(20) NOT NULL, Dipart CHAR(15), Stipendio NUMERIC(9) DEFAULT 0, FOREIGN KEY(Dipart) REFERENCES Dipartimento(NomeDip), UNIQUE (Cognome,Nome) ) 22

Chiavi su più attributi, attenzione Nome CHAR(20) NOT NULL, Cognome CHAR(20) NOT NULL, UNIQUE (Cognome,Nome), Nome CHAR(20) NOT NULL UNIQUE, Cognome CHAR(20) NOT NULL UNIQUE, Non è la stessa cosa! 23

Vincoli interrelazionali CHECK, vedremo più avanti REFERENCES e FOREIGN KEY permettono di definire vincoli di integrità referenziale di nuovo due sintassi per singoli attributi su più attributi E' possibile definire politiche di reazione alla violazione 24

Esempio di integrità referenziale (1) Infrazioni Vigili Codice 34321 53524 64521 73321 Matricola 3987 3295 9345 7543 Data Vigile Prov Numero 1/2/95 4/3/95 5/4/96 5/2/98 3987 3295 3295 9345 MI TO PR PR 39548K E39548 839548 839548 Cognome Nome Rossi Luca Neri Piero Neri Mario Mori Gino 25

Esempio di integrità referenziale (2) 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 Auto Prov Numero MI 39548K TO E39548 PR 839548 Cognome Rossi Rossi Neri Nome Mario Mario Luca 26

CREATE TABLE: esempio CREATE TABLE Infrazioni( Codice CHAR(6) NOT NULL PRIMARY KEY, Data DATE NOT NULL, Vigile INTEGER NOT NULL REFERENCES Vigili(Matricola), Provincia CHAR(2), Numero CHAR(6), FOREIGN KEY(Provincia, Numero) REFERENCES Auto(Provincia, Numero) ) 27

Politiche di reazione Specificata immediatamente dopo il vincolo di integrità consente di associare politiche diverse ai diversi eventi (delete, update) secondo la seguente sintassi: on < delete update > " < cascade set null! set default no action >! 28

Politiche di reazione: delete cascade: si propagano le cancellazioni. set null: all attributo referente viene assegnato il valore nullo al posto del valore cancellato nella tabella set default: all attributo referente viene assegnato il valore di default al posto del valore cancellato nella tabella esterna no action: la cancellazione non viene consentita 29

Politiche di reazione: update cascade: il nuovo valore viene propagato nell altra tabella. set null: all attributo referente viene assegnato il valore nullo al posto del valore modificato nella tabella. set default: all attributo referente viene assegnato il valore di default al posto del valore modificato nella tabella esterna. no action: l azione di modifica non viene consentita. 30

Modifiche degli schemi ALTER DOMAIN ALTER TABLE DROP DOMAIN DROP TABLE 31

ALTER DOMAIN Istruzione ALTER DOMAIN: Permette di effettuare modifiche sui domini creati in precedenza Deve essere utilizzato assieme ad uno di questi costrutti: SET DEFAULT, DROP DEFAULT, ADD CONSTRAINT o DROP CONSTRAINT 32

ALTER DOMAIN: esempio 1 ALTER DOMAIN Voto SET DEFAULT 30 Imposta il valore predefinito del domino con nome Voto a 30 Il valore predefinito viene applicato solo ai nuovi attributi senza valore, inseriti dopo l invocazione di tale comando ALTER DOMAIN Voto DROP DEFAULT Elimina il valore predefinito del dominio Voto 33

ALTER DOMAIN: esempio 2 ALTER DOMAIN Voto SET CONSTRAINT votovalido CHECK (value >=60 AND value <=100) Aggiunge il vincolo votovalido all interno del dominio Voto ALTER DOMAIN Voto DROP CONSTRAINT votovalido Elimina il vincolo legato al check 34

ALTER TABLE Istruzione ALTER TABLE: Permette di effettuare modifiche su tabelle create in precedenza Deve essere utilizzato assieme ad uno di questi parametri: ALTER COLUMN, ADD COLUMN, DROP COLUMN, DROP CONSTRAINT o ADD CONSTRAINT 35

ALTER TABLE: esempio 1 ALTER TABLE Impiegato ALTER COLUMN Matricola SET NOT NULL Impone che l attributo Matricola della tabella Impiegato non contenga valori nulli ALTER TABLE Impiegato ADD COLUMN Livello CHARACTER(10) Aggiunge l attributo Livello alla tabella Impiegato. 36

ALTER TABLE: esempio 2 ALTER TABLE Impiegato DROP COLUMN Livello RESTRICT Elimina l attributo Livello dalla tabella Impiegato solo se questi non contiene valori ALTER TABLE Impiegato DROP COLUMN Livello CASCADE Elimina l attributo Livello dalla tabella Impiegato ed i valori in esso contenuti 37

ALTER TABLE: esempio 3 ALTER TABLE Impiegato ADD CONSTRAINT matrvalida CHECK (char_length(matricola) = 10) Aggiunge il vincolo matrvalida all attributo Matricola della tabella Impiegato ALTER TABLE Impiegato DROP CONSTRAINT matrvalida Elimina il vincolo matrvalida dalla tabella Impiegato 38

DROP DOMAIN Istruzione DROP DOMAIN: cancella un domino definito da un utente Esempio: DROP DOMAIN Voto 39

DROP TABLE Istruzione DROP TABLE: consente di distruggere una tabella, eliminando i dati contenuti in essa. Esempio: DROP TABLE Infrazioni 40

Definizione degli indici è rilevante dal punto di vista delle prestazioni ma è a livello fisico e non logico in passato era importante perché in alcuni sistemi era l'unico mezzo per definire chiavi CREATE INDEX 41

CREATE INDEX: esempio CREATE INDEX idx_cognome ON Vigili (Cognome) Crea l indice idx_cognome sull attributo Cognome della tabella Vigili 42

DDL, in pratica In molti sistemi si utilizzano strumenti diversi dal codice SQL per definire lo schema della base di dati 43

SQL, operazioni sui dati interrogazione: SELECT modifica: INSERT, DELETE, UPDATE 44

Istruzione SELECT (versione base) SELECT ListaAttributi FROM ListaTabelle [ WHERE Condizione ] "target list" clausola FROM clausola WHERE 45

SELECT: come leggerla 3 1 2 SELECT Matricola, Nome FROM Vigili WHERE Cognome = Rossi 1 Dalla relazione Vigili 2 Filtra tutte le tuple con valore Rossi dell attributo Cognome 3 Mostrandomi per ciascuna tupla trovata la Matricola e il Nome 46

Persone Nome Età Andrea 27 Aldo 25 Maria 55 Anna 50 Filippo 26 Luigi 50 Franco 60 Olga 30 Sergio 85 Luisa 75 Base dati di esempio 2 Reddito 21 15 42 35 30 40 20 41 35 87 Maternita Madre Luisa Luisa Anna Anna Maria Maria Figlio Maria Luigi Olga Filippo Andrea Aldo Paternita Padre Sergio Luigi Luigi Franco Franco Figlio Franco Olga Filippo Andrea Aldo 47

Selezione e proiezione Nome e reddito delle persone con meno di trent anni PROJ Nome, Reddito(SEL Eta<30 (Persone)) select nome, reddito from persone where eta < 30 Persone Nome Età Reddito Andrea 27 21 21 Aldo 25 15 15 Maria Filippo 55 30 42 Anna 50 35 Filippo 26 30 Luigi 50 40 Franco 60 20 Olga 30 41 Sergio 85 35 Luisa 75 87 48

SELECT, abbreviazioni select nome, reddito from persone where eta < 30 select p.nome as nome, p.reddito as reddito from persone as p where p.eta < 30 49

Selezione, senza proiezione Nome, età e reddito delle persone con meno di trent anni SEL Eta<30 (Persone) select * from persone where eta < 30 Persone Nome Età Reddito Andrea 27 21 Aldo 25 15 Filippo Maria 26 55 30 42 Anna 50 35 Filippo 26 30 Luigi 50 40 Franco 60 20 Olga 30 41 Sergio 85 35 Luisa 75 87 50

Proiezione, senza selezione Nome e reddito di tutte le persone PROJ Nome, Reddito (Persone) select nome, reddito from persone Persone Nome Età Reddito Andrea 27 21 21 Aldo 25 15 15 Maria 55 Anna 50 Filippo 26 Luigi 50 Franco 60 Olga Olga 30 42 42 35 35 30 30 40 40 20 20 41 41 Sergio Sergio 85 35 35 Luisa Luisa 75 87 87 51

SELECT, abbreviazioni (1) select * from persone where eta < 30 select nome, età, reddito from persone where eta < 30 52

R(A,B) SELECT, abbreviazioni (2) select * from R equivale (intuitivamente) a select X.A as A, X.B as B from R X where true 53

Espressioni nella target list select Reddito/2 as redditosemestrale from Persone where Nome = 'Luigi' Persone Nome redditosemestrale Età Reddito Andrea 27 20 21 Aldo 25 15 Maria 55 42 Lugi 50 40 54

Condizione complessa select * from persone where reddito > 25 and (eta < 30 or eta > 60) Persone Nome Età Reddito Filippo 26 Franco Sergio 60 85 30 20 35 Olga 30 41 Sergio 85 35 55

Condizione LIKE Le persone che hanno un nome che inizia per 'A' e ha una 'd' come terza lettera select * from persone where nome like 'A_d%' 56

Condizione LIKE : esempio Persone Nome Età Reddito Andrea 27 21 Aldo 25 15 Maria 55 42 Anna 50 35 Filippo 26 30 Luigi 50 40 Franco 60 20 57

Gestione dei valori nulli Impiegati Matricola 5998 9553 9553 Cognome Filiale Età 7309 5998 Rossi Neri Milano Roma 32 45 Bruni Neri Milano NULL 45 Bruni Milano NULL Gli impiegati la cui età è o potrebbe essere maggiore di 40 SEL (Età > 40) OR (Età IS NULL) (Impiegati) 58

Esempio Gli impiegati la cui età è o potrebbe essere maggiore di 40 SEL Età > 40 OR Età IS NULL (Impiegati) select * from impiegati where eta > 40 or eta is null 59

Proiezione, osservazione: Matricola 7309 5998 9553 5698 Cognome Filiale Stipendio Neri Napoli 55 Neri Milano 64 Rossi Roma 44 Rossi Roma 64 cognome e filiale di tutti gli impiegati PROJ Cognome, Filiale (Impiegati) 60

Distinct select cognome, filiale from impiegati select distinct cognome, filiale from impiegati Cognome Neri Neri Rossi Rossi Filiale Napoli Milano Roma Roma Cognome Neri Neri Rossi Filiale Napoli Milano Roma 61

Selezione, proiezione e join Istruzioni SELECT con una sola relazione nella clausola FROM permettono di realizzare: selezioni, proiezioni, ridenominazioni con più relazioni nella FROM si realizzano join (e prodotti cartesiani) 62

SQL e algebra relazionale (1) R1(A1,A2) R2(A3,A4) select distinct R1.A1, R2.A4 from R1, R2 where R1.A2 = R2.A3 prodotto cartesiano (FROM) selezione (WHERE) proiezione (SELECT) 63

SQL e algebra relazionale (2) R1(A1,A2) R2(A3,A4) Select distinct R1.A1, R2.A4 from R1, R2 where R1.A2 = R2.A3 PROJ A1,A4 (SEL A2=A3 (R1 JOIN R2)) 64

SQL, alias e ridenominazione possono essere necessarie ridenominazioni nel prodotto cartesiano nella target list select X.A1 AS B1,... from R1 X, R2 Y, R1 Z where X.A2 = Y.A3 AND... 65

Equivalenza tra SQL e algebra relazionale select X.A1 AS B1, Y.A4 AS B2 from R1 X, R2 Y, R1 Z where X.A2 = Y.A3 AND Y.A4 = Z.A1 REN B1,B2 A1,A4 ( PROJ A1,A4 (SEL A2 = A3 AND A4 = C1 ( R1 JOIN R2 JOIN REN C1,C2 A1,A2 (R1)))) 66

SQL: esecuzione delle interrogazioni Le espressioni SQL sono dichiarative e noi ne stiamo vedendo la semantica In pratica, i DBMS eseguono le operazioni in modo efficiente, ad esempio: eseguono le selezioni al più presto se possibile, eseguono join e non prodotti cartesiani 67

SQL: specifica delle interrogazioni La capacità dei DBMS di "ottimizzare" le interrogazioni, rende (di solito) non necessario preoccuparsi dell'efficienza quando si specifica un'interrogazione È perciò più importante preoccuparsi della chiarezza (anche perché così è più difficile sbagliare ) 68

Persone Nome Età Andrea 27 Aldo 25 Maria 55 Anna 50 Filippo 26 Luigi 50 Franco 60 Olga 30 Sergio 85 Luisa 75 Base dati di esempio 2 Reddito 21 15 42 35 30 40 20 41 35 87 Maternita Madre Luisa Luisa Anna Anna Maria Maria Figlio Maria Luigi Olga Filippo Andrea Aldo Paternita Padre Sergio Luigi Luigi Franco Franco Figlio Franco Olga Filippo Andrea Aldo 69

Selezione, proiezione e join: esempio 1 I padri di persone che guadagnano più di 20 PROJ Padre (paternita JOIN Figlio =Nome SEL Reddito>20 (persone)) select distinct padre from persone, paternita where figlio = nome and reddito > 20 70

Selezione, proiezione e join: esempio 2 Le persone che guadagnano più dei rispettivi padri; mostrare nome, reddito e reddito del padre PROJ Nome, Reddito, RP (SEL Reddito>RP (REN NP,EP,RP ß Nome,Eta,Reddito (persone) JOIN NP=Padre (paternita JOIN Figlio =Nome persone))) select f.nome, f.reddito, p.reddito from persone p, paternita, persone f where p.nome = padre and figlio = f.nome and f.reddito > p.reddito 71

SELECT, con ridenominazione del risultato select figlio, f.reddito as reddito, p.reddito as redditopadre from persone p, paternita, persone f where p.nome = padre and figlio = f.nome and f.reddito > p.reddito 72

Join esplicito Padre e madre di ogni persona select paternita.figlio,padre, madre from maternita, paternita where paternita.figlio = maternita.figlio select madre, paternita.figlio, padre from maternita join paternita on paternita.figlio = maternita.figlio 73

SELECT con join esplicito, sintassi SELECT FROM Tabella { JOIN Tabella ON CondDiJoin }, [ WHERE AltraCondizione ] 74

SELECT con join esplicito: esempio Le persone che guadagnano più dei rispettivi padri; mostrare nome, reddito e reddito del padre select f.nome, f.reddito, p.reddito from persone p, paternita, persone f where p.nome = padre and figlio = f.nome and f.reddito > p.reddito select f.nome, f.reddito, p.reddito from (persone p join paternita on p.nome = padre) join persone f on figlio = f.nome where f.reddito > p.reddito 75

Ulteriore estensione: join naturale (meno diffuso) PROJ Figlio,Padre,Madre ( paternita JOIN Figlio = Nome REN Nome=Figlio (maternita)) paternita JOIN maternita select madre, paternita.figlio, padre from maternita join paternita on paternita.figlio = maternita.figlio select madre, figlio, padre from maternita natural join paternita 76

Outer join Con join e natural join, che possiamo chiamare anche inner join, puo capitare che alcuni valori di attributi delle tuple di partenza, non appaiano piu nel risultato finale. Per evitare questa perdita di informazione, se pur parziale, si puo usare un: left/right/full OUTER join Left e right join sono esterni per definizione, quindi la keyword OUTER puo essere omessa. 77

Left join Padre e, se nota, madre di ogni persona select paternita.figlio, padre, madre from paternita left join maternita on paternita.figlio = maternita.figlio paternita.figlio Franco Olga Filippo Andrea Aldo padre Sergio Luigi Luigi Franco Franco madre NULL Anna Anna Maria Maria 78

Left outer join Padre e, se nota, madre di ogni persona select paternita.figlio, padre, madre from paternita left outer join maternita on paternita.figlio = maternita.figlio paternita.figlio Franco Olga Filippo Andrea Aldo padre Sergio Luigi Luigi Franco Franco madre NULL Anna Anna Maria Maria Outer è opzionale in quanto equivalente al left join che è sempre un join esterno 79

Outer join select paternita.figlio, padre, madre from maternita join paternita on maternita.figlio = paternita.figlio select paternita.figlio, padre, madre from maternita left outer join paternita on maternita.figlio = paternita.figlio select paternita.figlio, padre, madre from maternita full outer join paternita on maternita.figlio = paternita.figlio Che cosa produce l ultima select? 80

Full Outer join: esempio paternita.figlio Maternita padre madre NULL Madre Figlio NULL Paternita Luisa NULL Luisa Maria NULL Padre Luisa Figlio Luisa Luigi Sergio Franco Olga Luigi Anna Anna Olga Luigi Olga Filippo Luigi Anna Anna Filippo Luigi Filippo Andrea Franco Maria Andrea Franco Andrea Maria Aldo Franco Franco Maria Aldo Maria Aldo Franco Sergio NULL Il full outer join restituisce il join interno esteso con le righe escluse di entrambe le tabella 81

Riassumendo 82

Ordinamento del risultato Nome e reddito delle persone con meno di trenta anni in ordine alfabetico select nome, reddito from persone where eta < 30 order by ASC nome Con order by i campi vengono ordinati in ordine alfabetico ascendente (order by ASC) o discendente (order by DISC) 83

Ordinamento del risultato: base dati d esempio Persone Nome Età Reddito Andrea 27 21 Aldo 25 15 Maria 55 42 Anna 50 35 Filippo 26 30 Luigi 50 40 Franco 60 20 Olga 30 41 Sergio 85 35 Luisa 75 87 84

Ordinamento del risultato select nome, reddito from persone where eta < 30 Persone Nome Reddito Andrea 21 Aldo 15 Filippo 30 select nome, reddito from persone where eta < 30 order by nome Persone Nome Reddito Aldo 15 Andrea 21 Filippo 30 Se non si specifica un verso per l ordinamento (ASC o DISC), order by ordina i dati in ordine ascendente 85

Ordinamento del risultato select nome, reddito from persone where eta < 30 order by nome ASC Persone Nome Reddito Aldo 15 Andrea 21 Filippo 30 select nome, reddito from persone where eta < 30 order by nome DISC Persone Nome Reddito Filippo 30 Andrea 21 Aldo 15 86

Unione, intersezione e differenza La select da sola non permette di fare unioni; serve un costrutto esplicito: select union [all] select... i duplicati vengono eliminati (a meno che si usi all). 87

Unione senza duplicati Effettua l unione tra gli attributi della prima SELECT con quelli della seconda, senza duplicare gli stessi valori Esempio: Select Figlio From Maternita union Select Figlio From Paternita Maternita UNION Paternita Maternita Figlio Paternita Madre Figlio Maria Padre Figlio Luisa Maria Luigi Sergio Franco Luisa Luigi Olga Luigi Olga Anna Olga Franco Luigi Filippo Filippo 88

Select Figlio From Maternita union all Select Figlio From Paternita Unione con duplicati Effettua l unione tra gli attributi della prima SELECT con quelli della seconda, duplicando gli attributi con lo stesso valore Esempio: Maternita UNION ALL Paternita Maternita Figlio Paternita Maria Madre Figlio Padre Figlio Luigi Luisa Maria Sergio Maria Olga Luisa Luigi Luigi Olga Maria Anna Olga Luigi Filippo Olga Filippo 89

Notazione posizionale (1) select padre, figlio from paternita union select madre, figlio from maternita Quali nomi per gli attributi del risultato? inventati o nessuno quelli del primo operando padre + madre 90

Notazione posizionale: il primo operando Padre Sergio Luigi Luigi Franco Franco Luisa Luisa Anna Anna Maria Maria Figlio Franco Olga Filippo Andrea Aldo Maria Luigi Olga Filippo Andrea Aldo 91

Notazione posizionale (2) select padre, figlio from paternita union select figlio, madre from maternita select padre, figlio from paternita union select madre, figlio from maternita In entrambi i casi il risultato dell unione ci darà sempre gli attributi padre e figlio 92

Differenza select Nome from Impiegato except select Cognome as Nome from Impiegato vedremo che si può esprimere con select nidificate 93

Intersezione select Nome from Impiegato intersect select Cognome as Nome from Impiegato equivale a select I.Nome from Impiegato I, Impiegato J where I.Nome = J.Cognome 94

Persone Nome Età Andrea 27 Aldo 25 Maria 55 Anna 50 Filippo 26 Luigi 50 Franco 60 Olga 30 Sergio 85 Luisa 75 Base dati di esempio 2 Reddito 21 15 42 35 30 40 20 41 35 87 Maternità Madre Luisa Luisa Anna Anna Maria Maria Figlio Maria Luigi Olga Filippo Andrea Aldo Paternità Padre Sergio Luigi Luigi Franco Franco Figlio Franco Olga Filippo Andrea Aldo 95

Interrogazioni nidificate le condizioni atomiche permettono anche il confronto fra un attributo (o più attributi, vedremo poi) e il risultato di una sottointerrogazione quantificazioni esistenziali 96

Interrogazioni nidificate: esempio 1 nome e reddito del padre di Franco select Nome, Reddito from Persone, Paternita where Nome = Padre and Figlio = 'Franco' select Nome, Reddito from Persone where Nome = (select Padre from Paternita where Figlio = 'Franco') 97

Interrogazioni nidificate, commenti La forma nidificata è meno dichiarativa, ma talvolta più leggibile (richiede meno variabili) La forma piana e quella nidificata possono essere combinate Le sottointerrogazioni non possono contenere operatori insiemistici ( l unione si fa solo al livello esterno ); la limitazione non è significativa 98

Interrogazioni nidificate: any, all Le sottointerrogazioni possono utilizzare gli operatori ANY e ALL. Con op= (>, <, =, >=,..) Attributo op ANY ( Sottoespressione ) Una riga soddisfa la condizione se risulta vero il confronto fra il valore dell attributo per la riga e almeno uno degli elementi restituiti dalla sottoespressione Attributo op ALL( Sottoespressione ) Una riga soddisfa la condizione se risulta vero il confronto fra il valore dell attributo per la riga e tutti gli elementi restituiti dalla sottoespressione 99

Interrogazioni nidificate: in Attributo IN( Sottoespressione ) Una riga soddisfa la condizione se il valore dell attributo per la riga e contenuto negli elementi restituiti dall interrogazione ANY, ALL e IN possono anche apparire negati, preceduti da NOT 100

Interrogazioni nidificate: esempio 2a Nome e reddito dei padri di persone che guadagnano più di 20 select distinct P.Nome, P.Reddito from Persone P, Paternita, Persone F where P.Nome = Padre and Figlio = F.Nome and F.Reddito > 20 select Nome, Reddito from Persone where Nome in (select Padre from Paternita where Figlio = any (select Nome from Persone where Reddito > 20)) notare la distinct 101

Interrogazioni nidificate: esempio 2b Nome e reddito dei padri di persone che guadagnano più di 20 select distinct P.Nome, P.Reddito from Persone P, Paternita, Persone F where P.Nome = Padre and Figlio = F.Nome and F.Reddito > 20 select Nome, Reddito from Persone where Nome in (select Padre from Paternita, Persone where Figlio = Nome and Reddito > 20) 102

Interrogazioni nidificate: esempio 3 Nome e reddito dei padri di persone che guadagnano più di 20, con indicazione del reddito del figlio select distinct P.Nome, P.Reddito, F.Reddito from Persone P, Paternita, Persone F where P.Nome = Padre and Figlio = F.Nome and F.Reddito > 20 Questa alternativa produce lo stesso risultato? select Nome, Reddito from Persone where Nome in (select Padre from Paternita where Figlio = any (select Nome from Persone where Reddito > 20)) 103

Soluzione select Nome, Reddito from Persone where Nome in (select Padre from Paternita where Figlio = any (select Nome from Persone where Reddito > 20) ) Nome Andrea Nome Franco Luigi Luigi Reddito 20 40 40 Padre Franco Luigi Luigi Maria Anna Filippo Luigi Olga Risposta: no, in quanto per ciascun padre non Sergio visualizziamo il reddito del figlio Luisa 104

Interrogazioni nidificate, commenti, 3 regole di visibilità: non è possibile fare riferimenti a variabili definite in blocchi più interni se un nome di variabile è omesso, si assume riferimento alla variabile più vicina in un blocco si può fare riferimento a variabili definite in blocchi più esterni; la semantica base (prodotto cartesiano, selezione, proiezione) non funziona più, vedremo presto perchè 105

Quantificazione esistenziale Ulteriore tipo di condizione EXISTS ( Sottoespressione) Il predicato e vero se la sottoespressione restituisce almeno una tupla 106

Quantificazione esistenziale: esempio 1 Le persone che hanno almeno un figlio select * from Persone where exists (select * from Paternita where Padre = Nome) or exists (select * from Maternita where Madre = Nome) 107

Quantificazione esistenziale: esempio 2 I padri i cui figli guadagnano tutti più di 20 select distinct Padre from Paternita Z where not exists ( select * from Paternita W, Persone where W.Padre = Z.Padre and W.Figlio = Nome and Reddito <= 20 ) 108

Quantificazione esistenziale: errore I padri i cui figli guadagnano tutti più di 20 select distinct Padre from Paternita where not exists ( select * from Persone where Figlio = Nome and Reddito <= 20 ) La variabile Figlio non ha una relazione di riferimento 109

Semantica delle espressioni correlate L interrogazione interna viene eseguita una volta per ciascuna ennupla dell interrogazione esterna 110

Scorretta: Visibilità select * from Impiegato where Dipart in ( select Nome from Dipartimento D1 where Nome = 'Produzione') or Dipart in ( select Nome from Dipartimento D2 where D2.Citta = D1.Citta ) Perché nell ultima select, D1 di Citta non è visibile 111

Differenza e nidificazione select Nome from Impiegato except select Cognome as Nome from Impiegato select Nome from Impiegato I where not exists (select * from Impiegato where Cognome = I.Nome) 112

Operatori aggregati Nelle espressioni della target list possiamo avere anche espressioni che calcolano valori a partire da insiemi di ennuple: conteggio, minimo, massimo, media, totale sintassi base (semplificata): Funzione ( [ DISTINCT ] * ) Funzione ( [ DISTINCT ] Attributo ) 113

Operatori aggregati: COUNT Il numero di figli di Franco select count(*) as NumFigliDiFranco from Paternita where Padre = 'Franco' l operatore aggregato (count) viene applicato al risultato dell interrogazione: select * from Paternita where Padre = 'Franco' 114

Operatori aggregati: esempio di COUNT Paternità Padre Sergio Luigi Luigi Franco Franco Figlio Franco Olga Filippo Andrea Aldo NumFigliDiFranco 2 115

Persone COUNT DISTINCT Nome Età Reddito Andrea 27 30 Aldo 25 24 Maria 55 36 Anna 50 36 select count(*) from persone 4 select count(distinct reddito) from persone 3 116

Altri operatori aggregati SUM, AVG, MAX, MIN Media dei redditi dei figli di Franco select avg(reddito) from persone join paternita on nome=figlio where padre='franco' 117

COUNT e valori nulli (1) Persone Nome Età Reddito Andrea 27 30 Aldo 25 NULL Maria 55 36 Anna 50 36 select count(*) from persone 4 select count(reddito) from persone 3 118

COUNT e valori nulli (2) Persone Nome Età Reddito Andrea 27 21 Aldo 25 NULL Maria 55 21 Anna 50 35 select count(distinct reddito) from persone 2 119

Operatori aggregati e valori nulli Persone Nome Età Reddito Andrea 27 21 Aldo 25 NULL Maria 55 21 Anna 50 35 select avg(reddito) as redditomedio from persone redditomedio 25,6 120

Operatori aggregati e target list un interrogazione scorretta: select nome, max(reddito) from persone di chi sarebbe il nome? La target list deve essere omogenea select min(eta), avg(reddito) from persone 121

Massimo e nidificazione La persona (o le persone) con il reddito massimo select * from persone where reddito = ( select max(reddito) from persone ) 122

Operatori aggregati e raggruppamenti Le funzioni possono essere applicate a partizioni delle relazioni Clausola GROUP BY: GROUP BY listaattributi 123

Operatori aggregati e raggruppamenti Il numero di figli di ciascun padre select Padre, count(*) AS NumFigli from paternita group by Padre Paternita Padre Sergio Luigi Luigi Franco Franco Figlio Franco Olga Filippo Andrea Aldo Padre NumFigli Sergio Luigi 1 2 Franco 2 124

Semantica di interrogazioni con operatori aggregati e raggruppamenti 1. interrogazione senza group by e senza operatori aggregati select * from paternita 2. si raggruppa e si applica l operatore aggregato a ciascun gruppo 125

Raggruppamenti e target list scorretta select padre, avg(f.reddito), p.reddito from persone f join paternita on figlio = f.nome join persone p on padre =p.nome group by padre corretta select padre, avg(f.reddito), p.reddito from persone f join paternita on figlio = f.nome join persone p on padre =p.nome group by padre, p.reddito 126

Condizioni sui gruppi I padri i cui figli hanno un reddito medio maggiore di 25; mostrare padre e reddito medio dei figli select padre, avg(f.reddito) from persone f join paternita on figlio = nome group by padre having avg(f.reddito) > 25 127

WHERE o HAVING? I padri i cui figli sotto i 30 anni hanno un reddito medio maggiore di 20 select padre, avg(f.reddito) from persone f join paternita on figlio = nome where eta < 30 group by padre having avg(f.reddito) > 20 128

select B, count (*) from R group by B Group by e valori nulli R B 11 2 null 2 A B 1 11 2 11 3 null 4 null select A, count (B) from R group by A select A, count (*) from R group by A A 1 1 2 1 3 1 4 1 A 1 1 2 1 3 0 4 0 129

Sintassi SELECT: risassumento SELECT ListaAttributiOEspressioni FROM ListaTabelle [ WHERE CondizioneSemplice] [ GROUP BY ListaAttributiDiRaggrup] [ HAVING CondizioniAggregate] [ ORDER BY ListaAttributiDiOrdinamento] 130

Operazioni di aggiornamento operazioni di inserimento: insert eliminazione: delete modifica: update di una o più ennuple di una relazione sulla base di una condizione che può coinvolgere anche altre relazioni 131

Inserimento INSERT INTO Tabella [ ( Attributi ) ] VALUES( Valori ) oppure INSERT INTO Tabella [ ( Attributi )] SELECT... 132

Inserimento: alcuni esempi INSERT INTO Persone VALUES ('Mario',25,52) INSERT INTO Persone(Nome, Eta, Reddito) VALUES('Pino',25,52) INSERT INTO Persone(Nome, Reddito) VALUES('Lino',55) INSERT INTO Persone ( Nome ) SELECT Padre FROM Paternita WHERE Padre NOT IN (SELECT Nome FROM Persone) 133

Inserimento, commenti L ordinamento degli attributi (se presente) e dei valori è significativo le due liste debbono avere lo stesso numero di elementi se la lista di attributi è omessa, si fa riferimento a tutti gli attributi della relazione, secondo l ordine con cui sono stati definiti se la lista di attributi non contiene tutti gli attributi della relazione, per gli altri viene inserito un valore nullo (che deve essere permesso) o un valore di default 134

Eliminazione di ennuple DELETE FROM Tabella [ WHERE Condizione ] 135

Eliminazione di ennuple: alcuni esempi DELETE FROM Persone WHERE Eta < 35 DELETE FROM Paternita WHERE Figlio NOT in ( SELECT Nome FROM Persone) DELETE FROM Paternita 136

Eliminazione, commenti elimina le ennuple che soddisfano la condizione può causare (se i vincoli di integrità referenziale sono definiti con politiche di reazione cascade) eliminazioni da altre relazioni ricordare: se la where viene omessa, si intende where true 137

Modifica di ennuple UPDATE NomeTabella SET Attributo = < Espressione SELECT NULL DEFAULT > [ WHERE Condizione ] 138

Modifica di ennuple: alcuni esempi Persone UPDATE Persone SET Reddito = 45 WHERE Nome = 'Piero' Nome Età Reddito Andrea 27 30 Aldo 25 15 Piero 55 36 45 UPDATE Persone SET Reddito = Reddito * 1.1 WHERE Eta < 30 Persone Nome Età Reddito Andrea 27 30 33 Aldo 25 16,5 15 Piero 55 36 139