• Non ci sono risultati.

Compito di Basi di Dati - Informatica 24 giugno 2010

N/A
N/A
Protected

Academic year: 2021

Condividi "Compito di Basi di Dati - Informatica 24 giugno 2010"

Copied!
2
0
0

Testo completo

(1)

Compito di Basi di Dati - Informatica

24 giugno 2010

Esercizio 1:

Sia dato uno schema relazionale, relativo alle associazioni di Informatica (ACM, IEEE, EATCS, AICA, GULP, ect.), costituito dalla coppia di relazioni:

QU OT A(SiglaAss, QuotaAss, Anno);

SOCI(CF socio, N omeSocio, SiglaAss, AnnoIscrizione).

La relazione QU OT A specifica l’ammontare della quota associativa di ogni associazione, che pu`o variare di anno in anno. La relazione SOCI contiene informazioni riguardanti gli iscritti alle varie associazioni.

Una persona pu`o essere iscritta a pi`u associazioni. Inoltre, per ogni associazione di cui una persona `e socia,

`

e indicato l’anno di prima iscrizione (quando una persona non rinnova l’iscrizione ad una associazione, la relativa tupla viene rimossa).

Definire preliminarmente le chiavi delle relazioni date. Successivamente, formulare opportune inter- rogazioni in algebra relazionale che permettano di determinare (senza usare l’operatore di divisione e usando solo se necessario le funzioni aggregate):

(a) i nomi delle persone che risultano iscritte solo all’associazione EATCS;

(b) i nomi delle persone che sono iscritte all’EATCS dall’anno 2005, o da un anno precedente (2004, 2003, ect.), o all’ACM dall’anno 2007, o da un anno successivo (2008, 2009, 2010);

(c) l’associazione (le associazioni se pi`u d’una) che nell’anno 2004 avevano la quota associativa pi`u alta;

(d) per ogni associazione, l’ammontare complessivo delle quote associative pagate relativamente all’anno 2009;

(e) le coppie (x, y) di soci tali che, nell’anno 2008, vi erano un’associazione A1 tale che sia x sia y erano soci di A1, un’associazione A2 tale che x era socio di A2 e y no, e un’associazione A3 tale che y era socio di A3 e x no.

Esercizio 2:

Con riferimento all’Esercizio 1, formulare opportune interrogazioni in SQL che permettano di determinare quanto richiesto (usando solo se necessario le funzioni aggregate).

Esercizio 3:

Si vuole progettare una base di dati di supporto all’organizzazione delle attivit`a di una compagnia aerea italiana.

La compagnia aerea offre un certo numero di voli caratterizzati da: un codice numerico che identifica univocamente il volo, il giorno in cui il volo viene effettuato (ad esempio, 24 giugno 2010; per semplicit`a, assumiamo che ogni volo inizi e termini lo stesso giorno), il tipo di aereo utilizzato, l’orario di partenza (ad esempio, ore 16:00) e l’orario di arrivo (ad esempio, ore 17:00), l’aeroporto di partenza (ad esempio, l’aeroporto Marco Polo di Venezia) e l’aeroporto di destinazione (ad esempio, Roma Fiumicino).

1

(2)

Ogni aeroporto sia identificato univocamente dal proprio nome. Di ogni aeroporto si memorizzano la citt`a e la nazione in cui si trova e il numero di piste disponibili. Ogni pista sia identificata da un numero all’interno dell’aeroporto di appartenenza (ad esempio, la pista numero 1 di Roma Fiumicino).

Di ogni tipo di aereo vengono registrati la societ`a costruttrice, il numero massimo di passeggeri e la quantit`a massima di merci che possono essere trasportati.

I voli si suddividono in voli nazionali ed internazionali. Dei voli passati interessa mantenere traccia dell’orario effettivo di partenza e di arrivo (ad esempio, 16:45 e 17:50); dei voli futuri interessa sapere il numero di posti prenotati e il numero di posti ancora disponibili.

Si definisca uno schema Entit`a-Relazioni che descriva il contenuto informativo del sistema, illustrando con chiarezza le eventuali assunzioni fatte. Lo schema dovr`a essere completato con attributi ragionevoli per ciascuna entit`a (identificando le possibili chiavi) e relazione. Vanno specificati accuratamente i vincoli di cardinalit`a e partecipazione di ciascuna relazione. Si definiscano anche eventuali regole aziendali (regole di derivazione e vincoli di integrit`a) necessarie per codificare alcuni dei requisiti attesi del sistema.

Esercizio 4:

Si descrivano le potenziali violazioni dei vincoli di integrit`a referenziale che possono essere causate da operazioni di modifica dei dati e le possibili politiche di reazione (supportate dal linguaggio SQL).

Riferimenti

Documenti correlati

La compagnia aerea offre un certo numero di voli caratterizzati da: un codice numerico che identifica univocamente il volo, il giorno in cui il volo viene effettuato (ad esempio,

Ogni azienda sia identificata univocamente da un codice e sia caratterizzata dal comune ove si trova l’ufficio di riferimento per la regione Friuli Venezia Giulia.. Si assuma

Si assuma un’organizzazione analoga per i libri presenti in magazzino, con due specificit` a: tutte le eventuali copie di uno stesso libro vengano collocate una accanto all’altra

Si assuma che ogni aeroplano possa avere una o pi` u aziende proprietarie (aeroplano condiviso da pi` u aziende) e che ogni azienda (proprietaria) possa essere proprietaria di uno o

Determinare il numero medio di accessi a blocco richiesto da una ricerca con indice secondario costruito su una chiave candidata (diversa dalla chiave primaria) di dimensione V 2 =

L’insegnante proprietario dell’account A2, non sapendo a quali altri insegnanti l’insegnante pro- prietario dell’account A1 abbia propagato i suoi privilegi, decida di concedere

Ogni supermercato appartenente ad una data catena di super- mercati di propriet` a di una determinata azienda sia identificato da un numero progressivo (supermercato numero 1

Determinare il numero medio di accessi a blocco richiesto da una ricerca con indice secondario costruito su un campo chiave V 0 , diverso dalla chiave primaria, di dimensione 9