Esercitazione: Interrogazioni SQL
|
|
|
- Eleonora Rossini
- 9 anni fa
- Просмотров:
Транскрипт
1 Laurea in Ingegneria Informatica SAPIENZA Università di Roma Insegnamento di Basi di Dati Esercitazione: Interrogazioni SQL Domenico Fabio Savo 1
2 Sommario 1. Creazione del database utilizzato per l esercitazione 2. Interrogazioni SQL 2
3 Creazione del database Creiamo un database denominato esempio utilizzando il client mysql. Le istruzioni da utilizzare sono: mysql> CREATE DATABASE esempio; Query OK, 1 row effected (0.06 sec) 3
4 Creazione delle tabelle (1/2) Vogliamo creare le seguenti tabelle: persone(nome, reddito, eta, sesso) nome è una stringa di 20 caratteri (chiave primaria) reddito è un intero di 10 cifre eta è un intero di 3 cifre sesso è un carattere genitori(figlio,genitore) figlio (stringa di 20 caratteri, chiave esterna su PERSONE) genitore (stringa di 20 caratteri, chiave esterna su PERSONE) chiave primaria formata da figlio e genitore 4
5 Creazione delle tabelle (2/2) - Creazione tabella Persone: mysql> CREATE TABLE Persone( Nome CHARACTER(20) PRIMARY KEY, Reddito NUMERIC(10), Eta NUMERIC(3), Sesso CHARACTER, ); - Creazione tabella Genitori: mysql> CREATE TABLE Genitori( Figlio CHARACTER(20) REFERENCES PERSONE(Nome), Genitore CHARACTER(20) REFERENCES PERSONE(Nome), PRIMARY KEY (Figlio,Genitore) ); 5
6 Inserimento dei dati nelle tabelle Per inserire dei dati in una tabella si utilizza l istruzione: INSERT INTO nome_tabella [(nome_attributo1,nome_attributo2,...)] VALUES (valore1,valore2,...); Attenzione: L ordinamento degli attributi (se presente) e dei valori è significativo. Le due liste di attributi e di valori devono 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. 6
7 ES: Inserimento dati Inseriamo alcune tuple nella tabella Persone(Nome, Reddito,Eta,Sesso) mysql> INSERT INTO PERSONE (Nome,Reddito,Eta,Sesso) VALUES ('Aldo',25,15,'M'); mysql> INSERT INTO PERSONE (Nome,Reddito,Eta,Sesso) VALUES ('Andrea',27,21,'M'); mysql> INSERT INTO PERSONE (Nome,Reddito,Eta,Sesso) VALUES ('Luisa',75,87,'F'); mysql> INSERT INTO PERSONE (Nome,Reddito,Eta,Sesso) VALUES ('Maria',55,42,'F'); 7
8 Interrogare un database Per effettuare un interrogazione in SQL si utilizza l istruzione SELECT SELECT nome_attributo,,nome_attributo FROM nome_tabella,,nome_tabella [WHERE condizione] Le tre parti sono solitamente chiamate: target list clausola from clausola where 8
9 Le ridenominazioni SQL permette di specificare un alias degli attributi (nella target list usando il comando AS) e delle tabelle (nella clausola FROM). La ridenominazione è usata per: 1. Ottenere segnature più esplicative nei risultati; 2. Evitare ambiguità; mysql> SELECT p1.nome as omonimosenior, p2.nome as omonimojunior FROM persone p1, persone p2 WHERE p1.nome = p2.nome and p1.eta > p2.eta; 9
10 Esercitazione prima parte Date le tabelle: genitori figlio genitore Effettuare le seguenti interrogazioni: 1. Trovare il nome delle persone con più di 30 anni; 2. Trovare nome e sesso delle persone con più di 30 e reddito superiore a 40; 3. Trovare nome e reddito dei genitori di Aldo'; 4. Trovare la relazione che mostra per ogni persona i nonni; 5. Trovare il reddito medio dei padri per età; 6. Trovare la relazione che mostra le coppie di fratelli (due persone sono fratelli se hanno un genitore in comune). 10
11 Soluzione (1) Trovare il nome e sesso delle persone con più di 30 anni mysql> SELECT nome FROM persone WHERE eta > 30; Nome Olga Luisa Maria rows in set (0.09 sec) 11
12 Soluzione (2) Trovare nome e sesso delle persone con più di 30 anni e reddito superiore a 40 mysql> SELECT nome, sesso FROM persone WHERE reddito > 40 AND eta > 30 ; Nome Sesso Luisa F Maria F rows in set (0.01 sec) 12
13 Soluzione (3) Trovare nome e reddito dei genitori di Aldo'; genitori figlio genitore mysql> SELECT genitore, reddito FROM persone, genitori WHERE figlio= Aldo' AND genitore=nome; 13
14 Soluzione (4) Trovare la relazione che mostra per ogni persona i nonni; genitori figlio genitore mysql> SELECT P.Figlio AS Nipote, N.Genitore AS Nonno FROM GENITORI P, GENITORI N WHERE P.Genitore=N.Figlio; 14
15 Soluzione (5) Trovare il reddito medio dei padri per età; genitori figlio genitore mysql> SELECT eta, AVG(reddito) AS AVG_REDDITO FROM Persone, Genitori WHERE nome = genitore AND sesso = 'M' GROUP BY eta; 15
16 Soluzione (6) Trovare la relazione che mostra le coppie di fratelli (due persone sono fratelli se hanno un genitore in comune). genitori figlio genitore mysql> SELECT distinct G1.Figlio AS Nome1, G2.Figlio AS Nome2 FROM GENITORI G1, GENITORI G2 WHERE G1.Genitore = G2.Genitore and G1.Figlio <> G2.Figlio; 16
17 Esercitazione seconda parte Date le tabelle: genitori figlio genitore Effettuare le seguenti interrogazioni: 7. Trovare le persone che sono genitori di almeno 2 figli; 8. Trovare la relazione che mostra per ciascun figlio i rispettivi genitori (Padre, Madre, Figlio); 9. Trovare l'elenco ordinato dei genitori i cui figli guadagnano tutti più di 20 milioni. 17
18 Soluzione (7) Trovare le persone che sono genitori di almeno 2 figli; genitori figlio genitore mysql> SELECT genitore FROM Genitori GROUP BY genitore HAVING COUNT(figlio) >= 2; 18
19 Soluzione (8) Trovare la relazione che mostra per ciascun figlio i rispettivi genitori (Padre, Madre, Figlio); genitori figlio genitore mysql> SELECT GP.Genitore AS Padre, GM.Genitore AS Madre, GP.Figlio FROM genitori GP, genitori GM, persone PP, persone PM WHERE GP.Figlio=GM.Figlio AND GP.Genitore=PP.Nome AND PP.Sesso='M' AND GM.Genitore=PM.Nome AND PM.Sesso='F'; 19
20 Soluzione (9) Trovare l'elenco ordinato dei genitori i cui figli guadagnano tutti più di 20 milioni. genitori figlio genitore mysql> SELECT DISTINCT genitore FROM Genitori WHERE genitore NOT IN (SELECT genitore FROM Genitori, Persone WHERE nome = figlio AND reddito <= 20) ORDER BY genitore; 20
Esercitazione: Il DBMS MySQL
Laurea in Ingegneria Informatica SAPIENZA Università di Roma Insegnamento di Basi di Dati Esercitazione: Il DBMS MySQL Domenico Fabio Savo 1 Cosa vedremo 1. Presentazione del DBMS MySQL 2. Come scaricare
Esercitazione: Il DBMS MySQL
Laurea in Ingegneria dei sistemi logistici Insegnamento di Sistemi di Elaborazione I Esercitazione: Il DBMS MySQL ing. Michelangelo DE BONIS [email protected] Indice della lezione 1. MySql 1. Download
Esercitazione: Il DBMS MySQL
Laurea in Ingegneria Informatica SAPIENZA Università di Roma Insegnamento di Basi di Dati Esercitazione: Il DBMS MySQL Domenico Fabio Savo 1 Cosa vedremo 1. Presentazione del DBMS MySQL 2. Come scaricare
Esercitazione: Il DBMS MySQL
Laurea in Ingegneria Informatica SAPIENZA Università di Roma Insegnamento di Basi di Dati Esercitazione: Il DBMS MySQL Marco Console Aspetti Organizzativi Marco Console Sito: www.dis.uniroma1.it/~console
Corso di. Basi di Dati I. 11. Esercitazioni in SQL: Altri esercizi
Corso di Basi di Dati 11. Esercitazioni in SQL: Altri esercizi A.A. 2016 2017 Esempio: consideriamo le seguenti tabelle Articoli(Id, Nome, Colore) Fornitori(Id, Nome, Indirizzo) Catalogo(Articolo, Fornitore,
3 SQL : Interrogazioni
Corso di Laurea in Ingegneria Gestionale SAPIENZA Università di Roma Esercitazioni del corso di Basi di Dati Prof.ssa Catarci e Prof.ssa Scannapieco Anno Accademico 2010/2011 Andrea Marrella Ultimo aggiornamento
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, SQL
Atzeni, Ceri, Paraboschi, Torlone Basi di dati McGraw-Hill, 1996-2002 : SQL Operazioni di aggiornamento operazioni di inserimento: insert eliminazione: delete modifica: update di una o più ennuple di una
Manuale 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,
SQL-DML/3. Basi di Dati. Prof. Alfredo Cuzzocrea Università degli Studi di Trieste
Basi di Dati Prof. Alfredo Cuzzocrea Università degli Studi di Trieste SQL-DML/3 Credits to: Prof. P. Atzeni UniRoma3 Prof. S. Ceri PoliMI Prof. S. Paraboschi UniBG Prof. R. Torlone UniRoma3 Operazioni
Esercitazione 3 SQL 2
Esercitazione 3 SQL 2 Basi di dati - prof. Silvio Salza - a.a. 2014-2015 E3-1 Schema della base di dati Persone (Nome, Sesso, Anno, Città) Discendenza (Genitore, Figlio) Stato (Città, Inizio, Fine, Stato)
Structured 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
Atzeni, 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
Operatori aggregati: COUNT
Operatori aggregati: COUNT Il numero di figli di select count(*) as NumFigliDi where Padre = '' Paternità Padre Sergio Figlio Olga Filippo Andrea Aldo l operatore aggregato (count) viene applicato al risultato
Corso di Basi di Dati A.A. 2015/2016
Corso di Laurea in Ingegneria Gestionale Sapienza Università di Roma Corso di Basi di Dati A.A. 2015/2016 E3 - MySQL: Creazione di Schemi ed Interrogazioni Tiziana Catarci, Andrea Marrella Ultimo aggiornamento
SQL - 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
Basi di Dati: Corso di laboratorio
Basi di Dati: Corso di laboratorio Lezione 3 Raffaella Gentilini 1 / 52 Sommario 1 Il DML di SQL: Interrogazione di una BD 2 / 52 Data Manipulation Language (DML) Istruzioni del DML Le istruzioni del DML
Basi 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
SQL 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
Operatori 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
SISTEMI 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
OBIETTIVI DELL'ESERCITAZIONE
Laurea in Ingegneria Informatica - Università di Roma "La Sapienza" Corso di Basi di Dati - A.A. 2005/2006 Esercitazione su SQL Giuseppe De Giacomo Domenico Lembo OBIETTIVI DELL'ESERCITAZIONE Creare schema
Select From Where...
Select From Where... SELECT Le colonne che saranno mostrate e in che ordine. Calcoli su colonne FROM La tabella o le tabelle usate dall interrogazione WHERE Condizione che deve essere soddisfatta dalle
Soluzione esercitazione 01
Soluzione esercitazione 01 Sistemi Informativi L-A Home Page del corso: http://www-db.deis.unibo.it/courses/sil-a/ Versione elettronica: SolEse01.pdf Sistemi Informativi L-A Videonoleggio - caso A: tabella
Esempio 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
2011 Politecnico di Torino 1
SQL per le applicazioni Esercitazione PHP e MySQL Svolgimento D B M G Passi di risoluzione creazione e popolamento della base di dati Creazione di un script SQL Passo 2 creazione di una query d interrogazione
SQL: 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
Caratteristiche dei linguaggi per Database
IL LINGUAGGIO Caratteristiche dei linguaggi per Database I linguaggi per basi di dati relazionali possiedono i comandi per: definizione del data base; manipolazione dei dati; associazione tra tabelle diverse;
