Progettazione di Sistemi Informatici
|
|
- Giorgio Ippolito
- 5 anni fa
- Visualizzazioni
Transcript
1 Progettazione di Sistemi Informatici OUTER JOIN e SUBQUERY Domenico Diacono Corso ADM Gennaio 2008
2 A che punto siamo Abbiamo visto la sintassi delle principali query SQL e delle istruzioni per l inserimento e la cancellazione dei dati. Sappiamo fare un INNER JOIN tra due tabelle, in corrispondenza di una relazione di FOREIGN KEY Ricarichiamo il DB di esempio.
3 INNER JOIN SELECT I.Nome, I.Sede, S.Citta FROM Imp I INNER JOIN Sedi S ON (I.Sede = S.Sede) WHERE I.Ruolo = Programmatore ; Nome Sede Citta Domenico S01 Milano Nicola S01 Milano Francesco S02 Bologna Angela S03 Milano La presenza di una FOREIGN KEY sul database è irrilevante. Sebbene forzi la coerenza dei dati è possibile farne a meno, delegando al software applicativo tale compito. L INNER JOIN nasce dalla LOGICA della query, non dalla struttura del DB!!
4 INNER JOIN L INNER JOIN restituisce le righe delle tabelle se trova il legame, altrimenti NON le mostra. Per capire meglio come funzionano i vari tipi di JOIN rimuoviamo la FOREIGN KEY dalla tabella imp, e immettiamo un paio di record relativi a due impiegati di una sede S04 non censita nella tabella Sedi
5 Modifiche al DB INSERT INTO imp (CodImp, Cognome, Nome, Sede) VALUES ('E009', 'Porpori','Giuseppe','S04'); ERROR 1452 (23000): Cannot add or update a child row: a foreign key constraint fails (`corsosql/imp`, CONSTRAINT `imp_ibfk_1` FOREIGN KEY (`Sede`) REFERENCES `sedi` (`Sede`) ON DELETE NO ACTION ON UPDATE CASCADE) ALTER TABLE imp DROP FOREIGN KEY imp_ibfk_1; INSERT INTO imp (CodImp, Cognome, Nome, Sede) VALUES ('E009', 'Porpori','Giuseppe','S04'); Query OK, 1 row affected (0.00 sec) INSERT INTO sedi (sede,responsabile,citta) VALUES ('S05','Castani','Bologna');
6 Contenuto del DB Cosa accade ora che esiste un record che si riferisce ad una sede non esistente, ed una sede senza impiegati? Attenzione: la situazione è ora inconsistente, dal punto di vista che avevamo adottato prima (un impiegato ha sempre una sede corrispondente nella tabella), ma potrebbe corrispondere ad una situazione valida nella realtà: è sempre il modello sottostante che determina la validità dei dati...
7 INNER JOIN SELECT I.Nome, I.Sede, S.Citta FROM Imp I INNER JOIN Sedi S ON (I.Sede = S.Sede) WHERE I.Ruolo = Programmatore ; Nome Sede Citta Domenico S01 Milano Nicola S01 Milano Francesco S02 Bologna Angela S03 Milano Come potete verificare la presenza dei due nuovi record non cambia l INNER JOIN. La logica che porta all uso di tale query non è cambiata: voglio sapere SOLO i nomi e la città di lavoro dei programmatori. Non mi interessano quindi i programmatori senza città... Che succede se nelle righe c è un valore NULL? Il NULL NON eguaglia alcun valore, tantomeno il NULL stesso., a meno che nella clausola di JOIN esplicita non si usi IS NULL o IS NOT NULL
8 OUTER JOIN Un OUTER JOIN non richiede che ogni record nella prima tabella ne abbia un altro nella seconda. La tabella che viene messa in OUTER JOIN conserva i suoi record, anche se non esiste un record corrispondente nella seconda tabella Gli OUTER JOIN si suddividono in LEFT, RIGHT e FULL, a seconda di quale tabella conservi le righe prive di match (sinistra, destra o entrambe) Non esiste nello standard SQL una notazione di OUTER JOIN implicita (nelle clausole WHERE)
9 LEFT OUTER JOIN Il risultato di un LEFT OUTER JOIN per le tabelle A e B contiene tutti i record della tabella sinistra (A), anche se NON esistono record corrispondenti nella tabella destra (B) Questo vuol dire che se la clausola ON non trova record corrispondenti nella tabella B, la riga ritornata avrà NULL in ogni colonna presa da B In altre parole un LEFT OUTER JOIN ritorna TUTTE le righe della tabella sinistra, più i valori corrispondenti nella tabella destra se esistono, altrimenti questi ultimi saranno NULL
10 LEFT OUTER JOIN SELECT I.Nome, I.Sede, S.Citta FROM Imp I LEFT OUTER JOIN Sedi S ON (I.Sede = S.Sede) WHERE I.Ruolo = Programmatore ; Nome Sede Citta Domenico S01 Milano Angela S03 Milano Nicola S01 Milano Francesco S02 Bologna Giuseppe S04 NULL La logica è: voglio sapere quali sono i programmatori, e nel caso in cui la sede abbia una città definita voglio sapere la città.
11 RIGHT OUTER JOIN SELECT I.Nome, I.Sede, S.Citta FROM Imp I RIGHT OUTER JOIN Sedi S ON (I.Sede = S.Sede); Nome Sede Citta Mario S01 Milano Domenico S01 Milano Maria S01 Milano Nicola S01 Milano Giovanni S02 Bologna Sabrina S02 Bologna Francesco S02 Bologna Angela S03 Milano NULL NULL Bologna
12 FULL OUTER JOIN In MySQL non è supportato direttamente, ma si può ottenere con una UNION SELECT I.Nome, I.Sede, S.Citta FROM Imp I LEFT JOIN Sedi S ON (I.Sede = S.Sede) WHERE I.Ruolo = Programmatore UNION SELECT I.Nome, I.Sede, S.Citta FROM Imp I RIGHT JOIN Sedi S ON (I.Sede = S.Sede) WHERE I.Sede IS NULL; Nome Sede Citta Domenico S01 Milano Angela S03 Milano Nicola S01 Milano Francesco S02 Bologna Giuseppe S04 NULL NULL NULL Bologna
13 JOIN tra più tabelle E possibile anche usare i JOIN tra più di due tabelle. In questo caso l operazione sarà logicamente suddivisa in più JOIN, ciascuno effettuato tra due tabelle; il risultato di ogni JOIN diventa una delle tabelle coinvolte nella JOIN successiva L ordine dipende dall ordine in cui sono elencate le tabelle e (a partire da MySQL 5.0.1) dall uso di parentesi FROM t1 JOIN t2 ON t1.col1=t2.col2 LEFT JOIN t3 ON t2.col3=t3.col3
14 Modifiche al DB Per i prossimi esempi usiamo il file: Scaricatelo, copiatelo sul desktop ed eseguite (Start->Esegui->cmd): Mysql u root p < DBDef2.txt Rispetto al precedente abbiamo aggiunto una sede e 3 nuovi impiegati, e ripristinato la FK
15 Subquery Oltre alla forma vista finora in SQL è possibile esprimere delle condizioni che si basano sul risultato di altre interrogazioni (dette subquery, o query innestate o query nidificate) Selezionare i codici degli impiegati delle sedi di Milano SELECT CodImp FROM imp WHERE Sede IN (SELECT Sede FROM sedi WHERE citta= Milano ) La subquery restituisce l insieme di sedi ( S01, S03 ) quindi la WHERE equivale a WHERE Sede IN ( S01, S03 );
16 Subquery scalari Gli operatori di confronto si possono usare solo se la subquery restituisce non più di un risultato Selezionare gli impiegati con lo stipendio minimo SELECT CodImp FROM imp WHERE Stipendio = (SELECT MIN(Stipendio) FROM imp) Selezionare il responsabile dell impiegato E001 SELECT Responsabile FROM sedi WHERE sede = (SELECT sede FROM imp WHERE CodImp= E001 );
17 Caso generale Se la subquery può restituire più di un valore allora si devono usare le forme 1. <operatore> ANY (almeno un valore) 2. <operatore> ALL (tutti i valori) Selezionare gli impiegati con stipendio minimo SELECT CodImp FROM imp WHERE stipendio <= ALL (SELECT Stipendio FROM imp)
18 Livelli multipli Una subquery può fare uso a sua volta di altre subquery. Il risultato si può a volte ottenere (ma non sempre) risolvendo a partire dal blocco più interno Selezionare gli impiegati che NON lavorano al progetto P02 SELECT CodImp FROM imp WHERE Sede IN (SELECT sede FROM sedi WHERE citta NOT IN (SELECT Citta FROM prog WHERE CodProg = P02 )); Attenzione perchè la query NON è equivalente a: WHERE sede IN (SELECT Sede FROM sedi,prog WHERE sedi.citta <> prog.citta AND prog.codprog = P02 );
19 Quantificatore esistenziale Mediante EXISTS (SELECT *...) è possibile verificare se il risultato di una subquery restituisce almeno una ennupla. Facendo uso di NOT EXISTS il predicato è vero se la subquery non restituisce alcuna ennupla. In entrambi i casi risultato non dipende dalla specifica ennupla riportata! Non è molto interessante... Ad esempio: SELECT sede FROM sedi WHERE EXISTS (SELECT * FROM imp WHERE ruolo= Programmatore );
20 Subquery correlate La subquery esistenziale diventa più interessante se fa riferimento a variabili definite nel blocco esterno... Selezionare le sedi che hanno almeno un programmatore SELECT sede FROM sedi S WHERE EXISTS (SELECT * FROM imp WHERE Ruolo = Programmatore AND Sede = S.sede); Il risultato della query innestata dipende dalla sede specifica, e la semantica quindi diventa: Per ogni ennupla del blocco esterno considera il valore di S.Sede e risolvi la query innestata Non è più possibile pensare che venga risolta prima la query interna e poi l esterna!
21 Unnesting E spesso possibile ricondursi ad una forma piatta, anche se non si tratta di cosa sempre ovvia. L esempio precedente si può scrivere: SELECT DISTINCT S.sede FROM sedi S, imp i WHERE S.sede= I.sede AND I.ruolo= programmatore Spesso è più semplice derivare la forma innestata dalla domanda posta... Si ricordi che in una subquery non si possono usare operatori insiemistici, e una subquery può comparire solo come operando destro.
22 Unnesting Con la negazione le cose tendono a complicarsi. Per trovare le sedi SENZA programmatori la forma innestata è immediata: SELECT S.sede FROM sedi S WHERE NOT EXISTS (SELECT * FROM imp WHERE Ruolo = Programmatore AND Sede = S.Sede); Ma nella forma piatta la query restituisce le sedi in cui lavora ALMENO un impiegato con ruolo diverso da programmatore: SELECT DISTINCT S.sede FROM sedi S JOIN Imp I ON (S.sede = I.sede) WHERE I.ruolo <> Programmatore ;
23 Unnesting Una soluzione piatta corretta (e + complessa) è: SELECT DISTINCT S.sede FROM sedi S LEFT JOIN Imp I ON (S.sede = I.sede ) AND (I.ruolo = Programmatore ) WHERE I.CodImp IS NULL; 1. Il JOIN restitusce tutte le sedi con i relativi impiegati nel ruolo di programmatore, comprese le sedi senza programmatori (OUTER JOIN) 2. La WHERE seleziona solo queste ultime sedi 3. E facile sbagliare: se avessi messo la selezione del ruolo nella where non avrei più avuto nulla: perchè?
24 Esercizio Sia dato il seguente schema relazionale: CD(int:NumCD, varchar(60):titolo, char(4):anno, float:prezzo) Traccia(NumCD, int:codicerec, int:trackno) Sessione(CodiceRec, varchar(60):titolocanzone, Anno) Compositore(varchar(60):NomeComp, CodiceRec) Cantante(varchar(60)NomeCant, CodiceRec) Un CD è fatto di n tracce, ed ogni traccia appartiene ad un CD Ogni traccia fa riferimento ad una sessione di registrazione La canzone registrata può avere definito un cantante ed un compositore, ma anche no...
25 Esercizio Scrivere le istruzioni per creare lo schema relazionale su MySQL, incluse PK e FK, in un nuovo database. Trovare le persone che hanno scritto e suonato canzoni il cui titolo inizia per D Trovare i titoli dei CD che contengono canzoni il cui anno di registrazione è sconosciuto Trovare le tracce del CD con numero di serie 3, fornendole in ordine di numero e indicando il cantante per le tracce per cui è definito
Il linguaggio SQL: query innestate
Il linguaggio SQL: query innestate Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLc-subquery.pdf Sistemi Informativi L-A DB di riferimento
DettagliIl linguaggio SQL: query innestate
Il linguaggio SQL: query innestate Sistemi Informativi T Versione elettronica: 04.4.SQL.subquery.pdf DB di riferimento per gli esempi Imp Sedi CodImp E001 E002 E003 Nome Rossi Verdi Bianchi Sede S02 Ruolo
DettagliIl linguaggio SQL: query innestate
Il linguaggio SQL: query innestate Sistemi Informativi T Versione elettronica: 04.4.SQL.subquery.pdf DB di riferimento per gli esempi Imp CodImp Nome Sede Ruolo Stipendio E001 Rossi S01 Analista 2000 E002
DettagliData Management Software. Il linguaggio SQL. Query Innestate. Paolo Avallone Sr Consulting IT Specialist DB2, Data Management 10 Settembre 2003
DB2 Data Management Software Il linguaggio SQL Query Innestate Paolo Avallone Sr Consulting IT Specialist DB2, Data Management 10 Settembre 2003 LEGGERE LE SEGUENTI ATTENZIONI Le informazioni contenute
DettagliBasi di Dati: Corso di laboratorio
Basi di Dati: Corso di laboratorio Lezioni 6 7 Raffaella Gentilini 1 / 46 Sommario 1 Subquery (o Interrogazioni Nidificate) Interrogazioni Annidate con Predicati di Confronto Interrogazioni Annidate con
DettagliProgettazione di Sistemi Informatici
Progettazione di Sistemi Informatici Raggruppamenti Domenico Diacono Corso ADM Gennaio 2008 A che punto siamo Finora abbiamo estratto dal DB informazioni relative a singole ennuple, eventualmente ottenute
DettagliIl linguaggio SQL: query innestate
Il linguaggio SQL: query innestate Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLc-subquery.pdf Sistemi Informativi L-A DB di riferimento
DettagliSQL. Università degli Studi di Salerno. Corso di Laurea in Scienze della Comunicazione Informatica generale (matr. Dispari) Docente: Angela Peduto
SQL Università degli Studi di Salerno Corso di Laurea in Scienze della Comunicazione Informatica generale (matr. Dispari) Docente: Angela Peduto A.A. 2005/2006 Select La forma di select cui siamo arrivati
DettagliSQL quick reference. piccolo manuale di riferimento dei principali comandi SQL (prof. Claudio Maccherani, Perugia, 2013)
SQL quick reference piccolo manuale di riferimento dei principali comandi SQL (prof. Claudio Maccherani, Perugia, 2013) I tipi dei dati di SQL sono: delimitatori delle costanti: TEXT(n) stringa di caratteri
DettagliSISTEMI INFORMATIVI E TELEMEDICINA INFORMATICA MEDICA. 3. Panoramica su SQL Prof. Mauro Giacomini
SISTEMI INFORMATIVI E TELEMEDICINA INFORMATICA MEDICA 3. Panoramica su SQL Prof. Mauro Giacomini Sommario Introduzione Istruzione SELECT Tipi di Join Subquery Comandi DML Creazione delle tabelle Introduzione
DettagliSQL - Structured Query Language
SQL - Structured Query Language Luca Martini Università di Pisa 16 aprile 2010 Riepilogo sugli operatori aggregati Sintassi SELECT A t t r i b u t o 1, MAX( A t t r i b u t o 2 ),... FROM Tabella1, Tabella2,...
DettagliSQL - Sottointerrogazioni
una delle ragioni che rendono SQL un linguaggio potente è la possibilità di esprimere interrogazioni più complesse in termini di interrogazioni più semplici, tramite il meccanismo delle subqueries (sottointerrogazioni)
DettagliPrincipi di Progettazione del Software a.a Il linguaggio SQL. Il Linguaggio SQL
Principi di Progettazione del Software a.a. 2017-2018 Ing. Università del Salento Il Linguaggio SQL Due componenti principali: Ø DDL (Data Definition Language) Contiene i costrutti necessari per la creazione/modifica
DettagliManuale SQL. Manuale SQL - 1 -
Manuale SQL - 1 - Istruzioni DDL Creazione di una tabella : CREATE TABLE Il comando CREATE TABLE consente di definire una tabella del database specificandone le colonne, con il tipo di dati ad esse associate,
DettagliInterrogazioni complesse. SQL avanzato 1
Interrogazioni complesse SQL avanzato Classificazione delle interrogazioni complesse Query con ordinamento Query con aggregazione Query con raggruppamento Query binarie Query annidate SQL avanzato 2 Esempio
DettagliTabelle esempio: Impiegato/Dipartimento
Informatica Generale (AA 07/08) Corso di laurea in Scienze della Comunicazione Facoltà di Lettere e Filosofia Università degli Studi di Salerno : SQL (3) Insiemistiche e Nidificate Prof. Alberto Postiglione
DettagliSQL. SQL: "storia. Sviluppato nella metà degli anni settanta (1974) presso il laboratorio di ricerca IBM di S.Josè. Dal 1983 ca. "standard di fatto"
SQL SQL: "storia Sviluppato nella metà degli anni settanta (194) presso il laboratorio di ricerca IBM di S.Josè Dal 1983 ca. "standard di fatto" E il linguaggio di riferimento per l interrogazione di DBMS
DettagliInterrogazioni in SQL
Interrogazioni in SQL Corso di Basi di Dati 4 dicembre 2013 1 Interrogazioni sullo schema aziendale 1. Ottenere i nomi dei dipartimenti dislocati in piú sedi. 2. Ottenere il numero di supervisori. 3. Produrre
DettagliInterpretazione delle query nidificate
Interpretazione delle query nidificate Per analizzare il risultato di una interrogazione nidificata si può supporre di valutare prima il risultato dell interrogazione nidificata (query interna) per poi
DettagliSQL - Structured Query Language
SQL - Structured Query Language Lab 05 Alessandro Lori Università di Pisa 27 Aprile 2012 Riepilogo esercitazione precedente Operatori insiemistici (UNION, INTERSECT, EXCEPT) Riepilogo esercitazione precedente
DettagliSQL. Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS)
1 SQL Laboratorio di Progettazione di Basi di Dati (CdS in Informatica e TPS) a.a. 2015/2016 http://www.di.uniba.it/~lisi/courses/basi-dati/bd2015-16.htm dott.ssa Francesca A. Lisi francesca.lisi@uniba.it
DettagliSQL [2] Concetti avanzati di SQL. Esempi di interrogazioni
SQL [2] Concetti avanzati di SQL 2 Esempi di interrogazioni 3 Esempi di interrogazioni 4 Esempi di interrogazioni 5 Confronti che coinvolgono NULL NULL può voler dire: valore sconosciuto (esiste ma non
DettagliA.Veneziani Vincoli di integrità e vincoli di integrità referenziale
A.Veneziani Vincoli di integrità e vincoli di integrità referenziale A cosa servono In genere in un DB i campi che definiscono le associazioni tra tabelle possono essere lasciati liberi di assumere qualsivoglia
DettagliDomande utili alla preparazione dell orale di Informatica all Esame di Stato
Domande utili alla preparazione dell orale di Informatica all Esame di Stato 1.Al livello fisico un database si appoggia ai files per contenere i suoi dati? 2.Esistono altri modelli di organizzazione oltre
DettagliSQL - Sottointerrogazioni correlate
SQL - Sottointerrogazioni correlate negli esempi visti ogni subquery viene eseguita una volta per tutte ed il valore (o insieme di valori) è usato nella clausola WHERE della query esterna è possibile definire
DettagliSQL e algebra relazionale
SQL e algebra relazionale Il linguaggio SQL consente una maggiore espressività dell algebra relazionale grazie a costrutti che permettono: di definire join più sofisticati di ordinare le righe dei risultati
DettagliESERCITAZIONE: AZIENDA
ESERCITAZIONE: AZIENDA Homework 24 ottobre 2002 Emanuel Weitschek emanuel@dia.uniroma3.it Prerequisiti (software) PostgreSQL pgadmin Driver JDBC Ambito Si consideri una base di dati che contiene informazioni
DettagliIl linguaggio SQL: raggruppamenti
Il linguaggio SQL: raggruppamenti Sistemi Informativi T Versione elettronica: 04.3.SQL.gruppi.pdf Informazioni di sintesi Quanto sinora visto permette di estrarre dal DB informazioni che si riferiscono
DettagliCorso di Informatica Linguaggio SQL prima parte
Corso di Informatica Linguaggio SQL prima parte Anno Accademico 2018-2019 Linguaggio SQL (Structured Query Language) 2 Il linguaggio SQL Un linguaggio per DBMS (DataBase Management System) deve permettere
DettagliOperatori aggregati. Operatori aggregati. Interrogazioni con raggruppamento. Interrogazioni con raggruppamento
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
DettagliBasi di dati - Laboratorio
Basi di dati - Laboratorio Corso di Laurea in Bioinformatica Docente: Barbara Oliboni Lezione 4 Contenuto della lezione Interrogazioni SQL Join interni ed esterni Uso di variabili tupla o ALIAS Interrogazioni
DettagliBasi di dati (4) Docente: Andrea Bulgarelli. Università di Modena e Reggio Emilia. Argomento: select (1.
Università di Modena e Reggio Emilia Basi di dati (4) Docente: andrea.bulgarelli@gmail.com Argomento: select (1.0) 1 Panoramica Select Joins Subquery Wildcard Esempi 2 SELECT SELECT [DISTINCT] [TOP n]
DettagliCorso di. Basi di Dati I. 9. Esercitazioni in SQL: Check, asserzioni, viste
Corso di Basi di Dati 9. Esercitazioni in SQL: Check, asserzioni, viste A.A. 2016 2017 Check Come abbiamo visto, SQL permette di specificare vincoli sugli attributi e le tabelle attraverso il comando check
DettagliQL (Query Language) Alice Pavarani
QL (Query Language) Alice Pavarani QL Query Language Linguaggio di interrogazione dei dati, permette di: Interrogare la base di dati per estrarre informazioni Elaborare i dati Il risultato di un interrogazione
DettagliManuale Comandi SQL SQL. Sito per esercitarsi (on line) SQL
Manuale Comandi SQL Sito per esercitarsi (on line)... 1 SQL... 1 Convenzioni e simboli usati... 2 Query Language... 2 Comando Select... 2 Order By:... 3 Sintassi generale:... 3 Ordinamanto su PIU campi...
DettagliFondamenti di Informatica A. A / 1 9
Fondamenti di Informatica Prof. Marco Lombardi A. A. 2 0 1 8 / 1 9 Concetti Introduttivi 1/2 SQL (Structured Query Language) permette di manipolare i dati, interrogare un database relazionale e modellarne
DettagliLaboratorio di Basi di Dati
Laboratorio di Basi di Dati Docente: Alberto Belussi Lezione 2 Vincoli di integrità Proprietà che devono essere soddisfatte da ogni istanza della base di dati. Il soddisfacimento è definito rispetto al
DettagliArchivi e basi di dati - ing. M. Cossentino. Settore. Traccia 1. Traccia 200. Settore non polarizzato
Settore Traccia 1 Traccia 200 Settore non polarizzato '! " # $ % & ( ) * + + ' ' ' !"#"$%, & &'(("% '&)'' ''"* - -. / / / 0/!- "-, (0 #- / / / 0/ --- + 1 ' # $ + 2 13 ,, - 4 '. & 56 2 '/!!! "7&% 8, 9 /'"'0'1'&'
DettagliBasi di Dati. Concetti Avanzati
Basi di Dati Concetti Avanzati Concetti Avanzati Raggruppamenti Clausole GROUP BY e HAVING Forma Generale della SELECT Nidificazione Uso nel DML e DDL Nidificazione, Viste e Potere Espressivo Esecuzione
DettagliLinguaggio SQL seconda parte
Linguaggio SQL seconda parte A. Lorenzi, E. Cavalli INFORMATICA PER SISTEMI INFORMATIVI AZIENDALI Copyright Istituto Italiano Edizioni Atlas Le condizioni di ricerca 2 Le condizioni di ricerca Usate nelle
DettagliTipi di sottoquery SQL
Tipi di sottoquery SQL È possibile specificare subquery in numerose posizioni: Con le parole chiave IN e NOT IN. Con operatori di confronto. Con le parole chiave ANY, SOME e ALL. Con le parole chiave EXISTS
DettagliIl linguaggio SQL: le basi
Il linguaggio SQL: le basi Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SQLa-basi.pdf Sistemi Informativi L-A SQL: caratteristiche generali
DettagliCorso di. Basi di Dati I. 7. Esercitazioni in SQL: Definizione e manipolazione dei dati
Corso di Basi di Dati 7. Esercitazioni in SQL: Definizione e manipolazione dei dati A.A. 2016 2017 Collegarsi a MySQL, caricare e salvare basi di dati Per collegarsi a mysql, aprire un terminale e inserire
DettagliIl linguaggio SQL: viste e tabelle derivate. DB di riferimento per gli esempi
Il linguaggio SQL: viste e tabelle derivate Dario Maio http://bias.csr.unibo.it/maio/ dmaio@deis.unibo.it 1 DB di riferimento per gli esempi Imp Sedi CodImp Nome Sede Ruolo Stipendio Sede Responsabile
DettagliSQL Matteo Magnani, Danilo Montesi Università di Bologna SQL. SQL come Data Manipulation Language - (SELECT FROM WHERE ORDER BY)
SQL SQL come Data Manipulation Language - (SELECT FROM WHERE ORDER BY) Esempio 1 Madre Maternita Figlio Nome Eta Andrea 27 Aldo 25 Maria 55 Anna 50 Filippo 26 50 60 Olga 30 Sergio 85 Luisa 75 Persone Reddito
DettagliEsame di Basi di Dati
Esame di Basi di Dati 11 Giugno 2013 Matricola CFU (9/12/9+9) Progetto (Sì/No) Cognome Nome Istruzioni I voti verranno resi disponibili su AlmaEsami. Chi vorrà rifiutare il voto dovrà comunicarlo tassativamente
DettagliIl linguaggio SQL: raggruppamenti. Versione elettronica: SQLb-gruppi.pdf
Il linguaggio SQL: raggruppamenti Versione elettronica: SQLb-gruppi.pdf Informazioni di sintesi Quanto sinora visto permette di estrarre dal DB informazioni che si riferiscono a singole tuple (eventualmente
DettagliPROGETTAZIONE DI DATABASE
ISTITUTO TECNICO INDUSTRIALE G. M. ANGIOY SASSARI PROGETTAZIONE DI DATABASE Manipolazione dei dati in SQL Lezione 12 Questa dispensa è rilasciata sotto la licenza Creative Common CC BY-NC-SA. Chiunque
DettagliSQL Esempi /10/2017 Basi di dati - SQL 1
SQL Esempi 23-26/10/2017 Basi di dati - SQL 1 Esercitazioni pratiche Per SQL è possibile (e fondamentale) svolgere esercitazioni pratiche Verranno anche richieste copme condizione per svolgere le prove
DettagliInterrogazioni in SQL SQL1 1
Interrogazioni in SQL SQL1 1 Dichiaratività di SQL E un linguaggio di IV generazione: in SQL l'utente specifica QUALE informazione è di suo interesse ma non COME estrarla dai dati il sistema costruisce
DettagliStructured Query Language
IL LINGUAGGIO SQL Structured Query Language Contiene sia il DDL sia il DML, quindi consente di: Definire e creare il database Effettuare l inserimento, la cancellazione, l aggiornamento dei record di un
DettagliBasi di Dati SQL-92. Dettagli e Approfondimenti
Basi di Dati SQL-92 Dettagli e Approfondimenti SQL-92 >> Sommario Dettagli e Approfondimenti DDL: Tabelle valori di default vincoli di riferimento modifiche allo schema DDL: Viste definizione e uso DDL:
DettagliCorso di. Basi di Dati I. 7. Esercitazioni in SQL: Definizione e manipolazione dei dati
Corso di Basi di Dati 7. Esercitazioni in SQL: Definizione e manipolazione dei dati A.A. 2016 2017 Collegarsi a MySQL, caricare e salvare basi di dati Per collegarsi a mysql, aprire un terminale e inserire
DettagliBasi di Dati. Esercitazione Algebra Relazionale e SQL. Ing. Paolo Cappellari. 15 maggio 2006
Basi di Dati Esercitazione Algebra Relazionale e SQL 15 maggio 2006 Ing. Paolo Cappellari Esercitazione Considerando la seguente base di dati: Fornitori (CodiceFornitore, Nome, Indirizzo, Città) Prodotti
DettagliAlessandra Raffaetà. Esercizio: Cinema
Lezione 8 S.I.T. PER LA VALUTAZIONE E GESTIONE DEL TERRITORIO Corso di Laurea Magistrale in Scienze Ambientali Alessandra Raffaetà Dipartimento di Informatica Università Ca Foscari Venezia Esercizio: Cinema
DettagliS.I.T. PER LA VALUTAZIONE E GESTIONE DEL TERRITORIO Corso di Laurea Magistrale in Scienze Ambientali. Alessandra Raffaetà
Lezione 8 S.I.T. PER LA VALUTAZIONE E GESTIONE DEL TERRITORIO Corso di Laurea Magistrale in Scienze Ambientali Alessandra Raffaetà Dipartimento di Informatica Università Ca Foscari Venezia Esercizio: Cinema
DettagliCorso di. Basi di Dati I. 8. Esercitazioni in SQL: Interrogazioni nidificate
Corso di Basi di Dati 8. Esercitazioni in SQL: Interrogazioni nidificate A.A. 2016 2017 Interrogazioni nidificate Come abbiamo visto, in una query SQL il comando where è seguito da un argomento che può
DettagliSi consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema:
BASI DI DATI INGEGNERIA INFORMATICA PROVA PRATICA 25 SETTEMBRE 2014 SOLUZIONI Si consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema: PAZIENTE(CodFiscale, Cognome,
DettagliAtzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1996-2002 : SQL Operatori aggregati Nelle espressioni della target list possiamo avere anche espressioni che calcolano valori a partire da insiemi
DettagliStructured. Language. Basi di Dati. Introduzione. DDL: Data Definition Language. Tipi di dato. Query. Modifica dei Dati
Basi di Dati Matteo Longhi Structured Query Language Introduzione Standard creato nel 1976 da IBM Aggiornato (versione 2 nel 1992 (ANSI X3.135 e ISO 9075 Consente di: DDL: definire la struttura del DB
DettagliSi consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema:
BASI DI DATI INGEGNERIA INFORMATICA PROVA PRATICA 20 LUGLIO 2015 SOLUZIONI Si consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema: PAZIENTECodFiscale, Cognome,
DettagliCorso di Basi di Dati
Corso di Basi di Dati Il Linguaggio SQL Home page del corso: http://www.cs.unibo.it/~difelice/dbsi/ Il Linguaggio SQL SQL (Structured Query Language) è il linguaggio di riferimento per le basi di dati
DettagliSQL Esempi. 24/10-7/11/2016 Basi di dati - SQL 1
SQL Esempi 24/10-7/11/2016 Basi di dati - SQL 1 Esercitazioni pratiche Per SQL è possibile (e fondamentale) svolgere esercitazioni pratiche Verranno anche richieste copme condizione per svolgere le prove
DettagliSELECT s.nome, e.data Studenti s, Esami e WHERE e.materia = 'BD' AND e.voto = 30 AND e.matricola = s.matricola
SQL SELECT s.nome, e.data FROM Studenti s, Esami e WHERE e.materia = 'BD' AND e.voto = 30 AND e.matricola = s.matricola SELECT s.nome As Nome, 2002 - s.annonascita As Eta, 0 As NumeroEsami FROM Studenti
DettagliProva Scritta di Basi di Dati
Prova Scritta di Basi di Dati 1 Luglio 2008 COGNOME: NOME: MATRICOLA: Si prega di risolvere gli esercizi direttamente sui fogli del testo, negli spazi indicati. Usare il foglio protocollo solo per la brutta
DettagliSELECT s.nome, e.data FROM Studenti s, Esami e WHERE e.materia = 'BD' AND e.voto = 30 AND e.matricola = s.matricola
SQL, e.data, Esami e WHERE e.materia = 'BD' AND e.voto = 30 AND e.matricola = s.matricola As Nome, 2002 - s.annonascita As Eta, 0 As NumeroEsami WHERE NOT EXISTS (SELECT * WHERE e.matricola = s.matricola
DettagliESERCIZI SQL. Esercizio 1
ESERCIZI SQL 2 Esercizio 1 3 Esercizio 1 4 Esercizio 1 Si specifichino le seguenti interrogazioni SQL sulla base di dati relazionale AZIENDA. Si mostri il risultato di ciascuna interrogazione. 1. Si restituisca
DettagliA.A. 2018/2019. Esercitazione 11. Strutturazione di Istruzioni in Linguaggio SQL. [ Possibili Soluzioni ] FONDAMENTI DI INFORMATICA E PROGRAMMAZIONE
A.A. 2018/2019 Esercitazione 11 Strutturazione di Istruzioni in Linguaggio SQL [ Possibili Soluzioni ] Docente Prof. Raffaele Pizzolante FONDAMENTI DI INFORMATICA E PROGRAMMAZIONE Esercizio 1 Scrivere
DettagliBasi di Dati. Dettagli e Approfondimenti SQL-92 25/02/2004. Dettagli e Approfondimenti. DDL: Tabelle. DML: Aggiornamenti.
Basi di Dati SQL-92 Dettagli e Approfondimenti SQL-92 >> Sommario Dettagli e Approfondimenti DDL: Tabelle valori di default vincoli di riferimento modifiche allo schema DDL: Viste definizione e uso DDL:
DettagliLezione 7 SQL (II) Basi di dati bis Docente Mauro Minenna Pag.1
Lezione 7 SQL (II) Pag.1 Ancora sugli operatori di confronto tra insiemi Abbiamo già visto IN, EXISTS e UNIQUE. Possiamo anche usare NOT IN, NOT EXISTS e NOT UNIQUE Disponibili anche: op ANY, op ALL Trovare
DettagliSQl come DML. Angelo Chianese,, Vincenzo Moscato, Antonio Picariello,, Lucio Sansone
SQl come DML Angelo Chianese,, Vincenzo Moscato, Antonio Picariello,, Lucio Sansone Basi di dati per la gestione dell'informazione 2/ed McGraw-Hill Capitolo 5 Appunti dalle lezioni SQL come DDL Sistemi
DettagliMicrosoft Access. Relazioni e query SQL. Domenico Fabio Savo
Microsoft Access Relazioni e query SQL Domenico Fabio Savo Outline Base di dati di esempio Le relazioni Le query Outline Base di dati di esempio Le relazioni Le query Contratti telefonici (requisiti) Si
DettagliBasi di Dati SQL-92. Dettagli e Approfondimenti
Basi di Dati SQL-92 Dettagli e Approfondimenti SQL-92 >> Sommario Dettagli e Approfondimenti DDL: Tabelle valori di default vincoli di riferimento modifiche allo schema DDL: Viste definizione e uso DDL:
DettagliIL MODELLO RELAZIONALE
Basi di dati 1 IL MODELLO RELAZIONALE (CAPITOLO 2) Codd 1970 Indipendenza dei dati Distinzione nella descrizione dei dati tra livello fisico e livello logico Vendors IBM,Informix,Microsoft,Oracle,Sybase
DettagliBasi di Dati: Corso di laboratorio
Basi di Dati: Corso di laboratorio Lezione 4 Raffaella Gentilini 1 / 27 Sommario 1 Join di Tabelle 2 3 2 / 27 Lo Statement JOIN Join espliciti di tabelle nella clausola FROM In SQL e possibile scrivere
DettagliSQL e ACCESS. Modello relazionale PROBLEMA ENTITA STUDENTE
SQL e ACCESS Prof. Salvatore Multazzu (salvatoremultazzu@tiscali.it) Applicazioni Informatiche nella comunicazione Modello relazionale Entità Record o Ennuple Attributi o Campi Tipi Chiavi Primarie (PK)
DettagliGestione delle informazioni. Tot. h 10. Base di Dati. Tot. h 56. Grafica in C# - Laboratorio- Tot. h 40. Dipartimento Informatica Materia Informatica
Dipartimento Informatica Materia Informatica Classe 5 Tec Ore/anno 198 A.S. 2018-2019 MODULI COMPETENZE UNITA di APPRENDIMENTO Gestione delle informazioni Tot. h 10 Base di Dati Tot. h 56 Grafica in C#
DettagliBasi di Dati. Esercitazione 1: Interrogazioni in SQL. K. Donno - Interrogazioni in SQL
Basi di Dati Esercitazione 1: Interrogazioni in SQL DB di riferimento per esempi Consideriamo i seguenti schemi di una base di dati relazionale: PremioProduzione, DataAssunzione) Viene data la seguente
DettagliBasi di Dati CREAZIONE E POPOLAMENTO DI UNA BASE DI DATI
Basi di Dati CREAZIONE E POPOLAMENTO DI UNA BASE DI DATI La finalità di questa esercitazione è quella di creare, date delle specifiche progettuale, appositi script di creazione e popolamento di una base
DettagliSi consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema:
BASI DI DATI ING. INFORMATICA PROVA PRATICA 10 LUGLIO 2013 SOLUZIONI Si consideri la realtà medica descritta dalla base di dati relazionale definita dal seguente schema: PAZIENTE(CodFiscale, Cognome, Nome,
DettagliSistemi di Elaborazione delle Informazioni
SCUOLA DI MEDICINA E CHIRURGIA Università degli Studi di Napoli Federico II Corso di Sistemi di Elaborazione delle Informazioni Dott. Francesco Rossi a.a. 2017/2018 1 Settima parte Interrogazione di una
DettagliIl linguaggio SQL: le basi. Versione elettronica: SQLa-basi.pdf
Il linguaggio SQL: le basi Versione elettronica: SQLa-basi.pdf SQL: caratteristiche generali SQL (Structured Query Language) è il linguaggio standard de facto per DBMS relazionali, che riunisce in sé funzionalità
DettagliDATABASE PER IL WEB. Programmazione Web 1
DATABASE PER IL WEB Programmazione Web 1 Archite3ura web con database Client Tier Web/App Tier DB Tier Client Web / App Server Database Il server web comunica con un altro server che con8ene il la banca
DettagliSQL: le funzioni di aggregazione
SQL: le funzioni di aggregazione funzioni predefinite che agiscono sui valori contenuti in insiemi di righe della tabella: Conteggi Somme Medie Massimi, minimi Funzione Count La funzione COUNT conta il
DettagliEsercitazione 4 SQL.
Esercitazione 4 SQL foglia@iet.unipi.it DB Riferimento Il database di riferimento è il database UNIPI, creare una nuova istanza di database sul server e caricare i dati CREATE TABLE 1. Creare una tabella
DettagliEsempio di database relazionale con l utilizzo del prodotto MySQL
Esempio di database relazionale con l utilizzo del prodotto MySQL Marco Liverani Aprile 2015 In queste pagine viene riportato in sintesi il progetto di un database relazionale esemplificativo con cui viene
DettagliTrasparenze rielaborate da Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999 Capitolo 4: SQL-2, seconda parte.
Trasparenze rielaborate da Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1999 Capitolo 4: SQL-2, seconda parte 11/03/2005 Maternità Legami logici Paternità Madre Luisa Luisa Anna Anna Padre
DettagliVersione 1.0. (DB Visite Specialistiche)
Appunti di Informatica SQL for COOL PEOPLE Versione 1.0 Lezione 04 (DB Visite Specialistiche) prof. Michele Salvemini 2015/2016 Sommario Impostazione della lezione... 4 pre-requisiti:... 4 Argomenti Trattati...
DettagliBasi di Dati. Esercitazione SQL. 18 maggio 2007
Basi di Dati Esercitazione SQL 18 maggio 2007 1 Considerando la seguente base di dati: Fornitori (CodiceFornitore, Nome, Indirizzo, Città) Prodotti (CodiceProdotto, Nome, Marca, Modello) Catalogo (CodiceFornitore,
DettagliCap. 7 -Trigger e loro uso
1 SOMMARIO 2 Introduzione... 3 Definizione standard di trigger... 10 Cap. 7 -Trigger e loro uso Uso dei trigger e integrità referenziale... 18 Comportamento attivo delle BD Si realizza disponendo di un
DettagliInformatica II Basi di Dati (07/08) Parte 2. 4 Accesso ai dati di un DB. Accesso ai dati di un DB. Accesso ai dati di un DB
Informatica II Basi di Dati (07/08) Parte 2 Gianluca Torta Dipartimento di Informatica dell Università di Torino torta@di.unito.it, 0116706782 4 Accesso ai dati di un DB SQL Accesso ai dati di un DB Aggiornamento
DettagliSQL. Argomenti della lezione. Join esplicito. Interrogazioni complesse in SQL join esplicito outer join operatori aggregati interrogazioni nidificate
Argomenti della lezione SQL Interrogazioni complesse in SQL join esplicito outer join operatori aggregati interrogazioni nidificate Maternità Paternità Madre Figlio Olga Filippo Sergio Olga Filippo Persone
DettagliDatabase 2 a puntata. Pablo Genova I. I. S. Angelo Omodeo Mortara Indirizzo Tecnico-Economico A. S.
Database 2 a puntata Pablo Genova gallini.genova@gmail.com I. I. S. Angelo Omodeo Mortara Indirizzo Tecnico-Economico A. S. 2017 2018 Esempi... dal modello relazionale al codice sql MODELLO RELAZIONALE
DettagliBASI di DATI. SQL: concetti fondamentali
BASI di DATI SQL: concetti fondamentali 1 SQL-92 >> Sommario Concetti Fondamentali Introduzione Creazione ed eliminazione di bd Creazione ed eliminazione di tabelle Inserimenti di ennuple Interrogazioni
Dettagli