Interrogazioni Le interrogazioni in SQL sono formulate in modo dichiarativo specificando cioè cosa si vuole ottenere e non come lo si vuole ottenere. L’interrogazione.

Slides:



Advertisements
Presentazioni simili
Interrogazioni Semplici Le operazioni di interrogazione vengono specificate per mezzo dellistruzione select select ListaAttributi from ListaTabelle [where.
Advertisements

Calcolo Relazionale.
Structured Query Language (SQL) Presentazione 13.1 Informatica Generale (Prof. Luca A. Ludovico)
Biglietti e Ritardi: schema E/R
Biglietti: schema E/R.
DML – Data Manipulation Language
Esercitazioni del Corso di Sistemi Informativi Marina Mongiello
Esercitazioni del Corso di Sistemi Informativi Marina Mongiello
SQL.
SQL Dati i seguenti schemi relazionali:
19/01/2014 Viste. 19/01/2014 Viste Le Viste Logiche o Viste o View possono essere definite come delle tabelle virtuali, i cui dati sono riaggregazioni.
Istruzione SELECT (versione base)
1 Corso di Laurea in Biotecnologie Informatica (Basi di Dati) SQL: Data Manipulation Language (DML) Anno Accademico 2009/2010 Da: Atzeni, Ceri, Paraboschi,
Laboratorio di Basi di Dati Introduzione ad Access 2ª Parte.
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999
SQL: Lezione 7 Nataliya Rassadko
Esercitazione.
Algebra Relazionale Linguaggio procedurale, cioè le operazioni vengono descritte attraverso la descrizione della sequenza di azioni da compiere per ottenere.
Duplicati Lalgebra relazionale non ammette duplicati, SQL li ammette. Quindi select Città from Persona where Cognome= Rossi estrae una lista di città in.
Vincoli di integrità generici Con i costrutti visti sinora, non è sempre possibile definire tutti i possibili vincoli di integrità. Per questo esiste listruzione.
Manipolazione dei dati I comandi SQL che permettono di modificare il contenuto di una base di dati sono insertdeleteupdate insert ha la seguente sintassi:
SELECT STATEMENT Clausola WHERE permette di limitare il numero di record da estrarre SELECT */ [DISTINCT] colonna/ espressione [alias],… FROM table [WHERE.
Viste. Cosè una vista? è possibile creare un subset logico di dati o una combinazione di dati una vista è una tabella logica basata su una tabella o su.
SQL basato su ANSI (American National Standards Institute) – standard SQL SQL – Structured Query Language è un linguaggio dichiarativo e permette di comunicare.
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, Capitolo 4:SQL 16/10/2002.
Basi di dati Claudia Raibulet
SQL: Structured Query Language
Corso di INFORMATICA anno scolastico 2009/10 Linguaggio SQL OPERATORI INSIEMISTICI IN SQL Siano due tabelle: GiochiSolitari(CodiceGioco, NomeGioco, PrezzoGioco)
Corso di INFORMATICA anno scolastico 2009/10 Linguaggio SQL IDENTIFICATORI di tabelle e attributi: stringhe di lunghezza max 18 caratteri, composte da.
MODELLO LOGICO DEI DATI
Gerarchie Ricorsive Una gerarchia ricorsiva deriva dalla presenza di una ricorsione o ciclo (un anello nel caso più semplice) nello schema operazionale.
SQL.
Basi di dati - Modelli e linguaggi di interrogazione- Paolo Atzeni, Stefano Ceri, Stefano Paraboschi, Riccardo Torlone Copyright © The McGraw-Hill.
Sistemi Informativi Insieme di “strutture” in grado di acquisire, elaborare, trasmettere ed archiviare informazioni in genere ad uso di un’organizzazione.
Informatica II – Basi di Dati (07/08) – Parte 2 Gianluca Torta Dipartimento di Informatica dell’Università di Torino
SQL Interrogazioni. 2 Interrogazioni in SQL Non esiste un SQL standard (vari dialetti) Formulazione di interrogazioni (query) è parte del Data Manipulation.
Informatica Introduzione alle basi di dati Lezione 8 Scienze e tecniche psicologiche dello sviluppo e dell'educazione, laurea magistrale Anno accademico:
Microsoft Access (parte 5) Introduzione alle basi di dati Scienze e tecniche psicologiche dello sviluppo e dell'educazione, laurea magistrale Anno accademico:
1 Data warehousing con SQL Server SQL Server è un RDBMS (Relational DataBase Management System) Analysis Services è un componente di SQL Server che offre.
SEFOC – SETTORE FORMAZIONE CONTINUA DEL PERSONALE CORSO MYSQL AVANZATO ROBERTO PENNOLINO – CARMELO MASSIMO PRIOLO PALERMO – 07 | 06 | 2011.
Basi di dati I Prof.ssa Rosalba Giugno Prof. Alfredo Pulvirenti SQL :Structured Query Language: SELECT (IV) SQL (Slide tratte in parte da da Atzeni, Ceri,
Le query in SQL Unità didattica sviluppata per l’ITIS “A. Volta” – Classe 5 sez. I Ing Domenico Liguori - Università degli studi di Napoli “Federico.
Il Linguaggio SQL. Le interrogazioni in SQL (continua…) La parte di SQL dedicata alla formulazione di interrogazioni fa parte del DML. SQL esprime le.
SQL, esempi 30/10/2014Basi di dati SQL1. 30/10/2014Basi di dati SQL2 CREATE TABLE, esempi CREATE TABLE corsi( codice numeric NOT NULL PRIMARY KEY, titolo.
Algebra relazionale (III). Esempi di Interrogazioni: 3 Trovare matricola e nome dei capi i cui impiegati guadagnano tutti più di Tutti gli impiegati?
Raggruppamento in SQL Esempio di raggruppamento
Interrogazioni (parte 2)
Basi di dati e Relazioni Uno schema di relazione R(X) è costituito da un simbolo (nome della relazione) R e da una serie di attributi X={A 1, A 2, …, A.
Basi di dati I Prof.ssa Rosalba Giugno Prof. Alfredo Pulvirenti SQL :Structured Query Language: SELECT (III) SQL (Slide tratte in parte da da Atzeni, Ceri,
Query languages per Basi di Dati Relazionali  Algebra Relazionale:  basato sulla teoria degli insiemi  procedurale  usato per l’implementazione di.
Join Proprietà Il join di r 1 e r 2 contiene un numero di tuple compreso fra zero e il prodotto di |r 1 | e |r 2 | se il join di r 1 e r 2 è completo allora.
Vincoli Interrelazionali Per i vincoli visti l’inserimento di un valore che li viola viene semplicemente impedito. In caso di vincoli di integrità referenziale,
Vincoli interrelazionali
Raggruppamenti e target list scorretta select padre, avg(f.reddito), p.reddito from persone f join paternita on figlio = nome join persone p on padre =
Lezione 6 - SQL. Linguaggi per DB Per interagire con le basi di dati occorre un linguaggio Linguaggio SQL (Structured Query Language), linguaggio standardizzato.
Prof. Lorenzo Vita, Ing. Luigi Testa
Interrogazioni Le interrogazioni in SQL sono formulate in modo dichiarativo specificando cioè cosa si vuole ottenere e non come lo si vuole ottenere. L’interrogazione.
Funzionalità del DBMS relazionale l Funzioni per –definizione della base di dati –inserimento / rimozione /aggiornamento di informazioni deve soddisfare.
Approfondimenti SQL.
Operazioni Relazionali
Linguaggio SQL prima parte Linguaggio SQL prima parte A. Lorenzi, E. Cavalli INFORMATICA PER SISTEMI INFORMATIVI AZIENDALI Copyright © Istituto Italiano.
SQL Linguaggio per l’interrogazione di una base dati.
E. Tinelli SQL come linguaggio di manipolazione dei dati 1 DML – Data Manipulation Language.
Il linguaggio SQL (Structured Query Language) è il linguaggio standard per creare, manipolare e interrogare database relazionali. SQL non è case-sensitive:
Esercizi SQL Group by. CREATE TABLE dipendente (codDip CHAR(8) NOT NULL UNIQUE PRIMARY KEY, cognome CHAR(60) NOT NULL, nome CHAR(60) NOT NULL, stipendio.
Universita’ di Milano Bicocca Corso di Basi di dati 1 in eLearning C
Universita’ di Milano Bicocca Corso di Basi di dati 1 in eLearning C
Universita’ di Milano Bicocca Corso di Basi di dati 1 in eLearning C
Universita’ di Milano Bicocca Corso di Basi di dati 1 in eLearning C
Interrogazioni Le interrogazioni in SQL sono formulate in modo dichiarativo specificando cioè cosa si vuole ottenere e non come lo si vuole ottenere.
Transcript della presentazione:

Interrogazioni Le interrogazioni in SQL sono formulate in modo dichiarativo specificando cioè cosa si vuole ottenere e non come lo si vuole ottenere. L’interrogazione viene passata all’ottimizzatore di interrogazioni (query optimizer) che fa parte del DBMS. Questo la analizza e la traduce nel linguaggio di interrogazione interno al DBMS. Per questo chi programma in SQL deve cercare di scrivere codice leggibile e facilmente modificabile, piuttosto che efficiente.

Interrogazioni L’istruzione base per le interrogazioni è select select ListaAttributi(target list) from ListaTabelle(clausola from ) [ where Condizione ] (clausola where ) Più in dettaglio: select AttrEspr [[as] Alias ]{, AttrEspr [[as] Alias ]} from Tabella [[as] Alias ]{, Tabella [[as] Alias ]} [ where Condizione ] Seleziona le righe che soddisfano la condizione where fra quelle appartenenti al prodotto cartesiano delle tabelle in ListaTabelle. Ogni colonna (tabella) può essere ridenominata con un alias.

Interrogazioni Es. Data una base di dati che contiene le tabelle: IMPIEGATO (Nome, Cognome, Dipart, Ufficio, Stipendio, Città) DIPARTIMENTO (Nome, Indirizzo,Città) select Stipendio/12 as SalarioMensile from Impiegato where Cognome = `Rossi` Il risultato è una tabella con una colonna rinominata SalarioMensile e tante righe quanti sono gli impiegati che si chiamano Rossi. Se si usa * dopo select si selezionano tutti gli attributi

NomeEtà Persone Reddito Andrea27 Maria55 Anna50 Filippo26 Luigi50 Franco60 Olga30 Sergio85 Luisa75 Aldo Madre Maternità Figlio Luisa Anna Maria Luisa Maria Olga Filippo Andrea Aldo Luigi Padre Paternità Figlio Luigi Franco Sergio Olga Filippo Andrea Aldo Franco

Selezione e proiezione Nome e reddito delle persone con meno di trenta anni PROJ Nome, Reddito (SEL Eta<30 (Persone)) 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

Interrogazioni su più tabelle Se si vogliono estrarre informazioni da più tabelle, tutte le tabelle devono apparire come argomento della clausola from. Se si deve formulare un join, è possibile farlo in modo esplicito ( from reggerà allora un join fra le tabelle) oppure inserendo la condizione di join nella clausola where. Infatti, specificare una lista di tabelle nella clausola from equivale ad eseguire la query sul prodotto cartesiano delle tabelle riportate nella lista, e un theta-join equivale a un prodotto cartesiano seguito da una selezione sulla condizione di join.

Interrogazioni su più tabelle Es. Estrarre i nomi degli impiegati e le città dove lavorano. Select Impiegato.Nome,Impiegato.Cognome, Dipartimento.Città from Impiegato, Dipartimento where Impiegato.Dipart=Dipartimento.Nome

Interrogazioni su più tabelle E’ possibile omettere il nome della tabella per quegli attributi che non presentano ambiguità. select Impiegato.Nome, Cognome, Dipartimento.Città from Impiegato, Dipartimento where Dipart = Dipartimento.Nome e abbreviare ulteriormente il codice utilizzando gli alias select I.Nome, Cognome, D.Città from Impiegato as I, Dipartimento as D where Dipart = D.Nome

Clausola where Ammette come argomento una condizione logica. Gli operatori ammessi per i predicati semplici (confronto attributo- costante o attributo-espressione) sono =, <>,, = I predicati semplici possono essere modificati tramite gli operatori logici and, or, not. not ha precedenza su and e or, ma non è definita la precedenza fra and e or. Quando si coordinano più predicati con and e or è bene esplicitare le precedenze con le parentesi. Es. select Nome from Impiegato where Cognome = ‘Rossi’ and (Dipart = ‘Amministraz’ or Dipart = ‘Produz’)

Operatore like Per i confronti fra stringhe è definito anche l’operatore like. Il confronto è effettuato con una stringa che può contenere i caratteri speciali % e _. _ rappresenta un carattere arbitrario % rappresenta in numero arbitrario di caratteri (anche zero). Es. select * from Impiegato where Cognome like ‘_o%i’ La condizione è soddisfatta da Rossi Borroni Poli Pollastri ecc.

Gestione dei valori nulli La gestione dei valori nulli, a seconda dell’implementazione, avviene attraverso una logica a due valori come nell’SQL-89, o a tre valori (vero, falso, unknown) come nell’SQL-2. Le condizioni sui valori nulli possono essere definite attraverso i predicati is null o is not null.

Interpretazione algebrica delle interrogazioni E’ possibile mettere in corrispondenza interrogazioni SQL ed espressioni equivalenti in algebra relazionale. select T 1.Attributo 11, …. T h.Attributo hm from Tabella 1 as T 1,.... Tabella h as T h where Condizione equivale a  T1.Attributo Th.Attributohm  Condizione (Tabella 1 x Tabella 2 x.... x Tabella h ) ) Espressioni più complicate hanno comunque una traduzione, anche se non così diretta.

Duplicati L’algebra relazionale non ammette duplicati, SQL li ammette. Quindi select Città from Persona where Cognome= ‘Rossi’ estrae una lista di città in cui una città può comparire più volte. Per evitare i duplicati SQL prevede la specifica distinct da inserire subito dopo select. select distinct Città from Persona where Cognome= ‘Rossi’

Join In SQL-2 è stata introdotta la seguente sintassi per esprimere il join ed estenderlo ai join esterni select AttrEspr [[as] Alias ]{, AttrEspr [[as] Alias ]} from Tabella [[as] Alias ] {[ TipoJoin ]join Tabella [[as] Alias ]on CondizioneJoin } [ where AltraCondizione ] TipoJoin può assumere i valori inner,right[outer],left[outer],full[outer] inner è il default. C’è anche l’estensione natural che implica la condizione di uguaglianza sugli attributi con lo stesso nome.

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

Alias e variabili L’uso degli alias consente di: compattare il codice fare riferimento a più esemplari della stessa tabella creare interrogazioni nidificate Se una tabella compare una sola volta non c’è differenza fra variabile ed alias. Se compare più volte si parla più propriamente di variabile. Es. (impiegati il cui nome è anche il cognome di un altro impiegato) select I1.Cognome, I1.Nome from Impiegato I1, Impiegato I2 where I1.Nome = I2.Cognome and I1.Nome <> I2.Nome and I2.Dipart = ‘Produzione’

Ordinamento E’ possibile anche ordinare le righe del risultato di una interrogazione attraverso la clausola order by, a chiusura di una interrogazione. order by AttrdiOrdinamento [asc | desc] {, AttrdiOrdinamento [asc | desc]} asc (default) indica ordinamento ascendente, desc discendente. Il primo attributo ha priorità, a parità di valore il secondo ecc. select * from Persona order by Cognome, Nome

Operatori aggregati In algebra relazionale le espressioni vengono valutate sulle singole tuple in successione. Talvolta però possono essere necessarie informazioni derivabili dall’esame di tutte le tuple o di più tuple contemporaneamente. SQL prevede una serie di operatori aggregati: count, sum, max, min, avg con sintassi count ( ) ([distinct | all] AttrEspr ) Es. Determinare il numero degli impiegati che si chiamano Rossi select count(*) from Impiegato where nome= ‘Rossi’

Interrogazioni con raggruppamento Gli operatori aggregati vengono applicati a tutte le righe che vengono prodotte come risultato dell’interrogazione. Può essere necessario applicare l’operatore separatamente ad uno o più sottoinsiemi delle righe. SQL non ammette che nella stessa target list compaiano funzioni aggregate ed espressioni a livello di riga, come il nome di un attributo. Come si potrebbe associare un singolo risultato a un attributo che può assumere più valori ?

Interrogazioni con raggruppamento L’operatore group by specifica come suddividere le tabelle in sottoinsiemi omogenei per valore su cui valutare separatamente l’operatore aggregato. Es. select Dipart, sum(Stipendio) from Impiegato group by Dipart (calcola una somma per ogni valore assunto da Dipart)

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

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

Interrogazioni con raggruppamento In ogni interrogazione che usa group by, argomento di select (escludendo l’operatore aggregato) può essere solo un sottoinsieme degli attributi usati nella clausola group by Es. di interrogazione scorretta select Ufficio from Impiegato group by Dipart Poiché deve venire prodotta una sola riga per ogni valore di Dipart, e, a parità di tale valore, possono aversi diversi valori di Ufficio, il risultato dell’interrogazione è indeterminato. In alcuni casi (es. se l’attributo non compreso nella clausola group by è chiave) la query potrebbe fornire un risultato corretto, ma per semplicità SQL lo vieta comunque.