PDA

View Full Version : [SQL] Mi è andato in panne il cervellino...


-Ivan-
01-12-2008, 18:30
Problema apparentemente facile che non riesco proprio ad afferrare:

ho queste tabelle:

ATTORE ( codAttore, cognome, nome, dataNascita)
SPETTACOLO ( codSpettacolo, nomeSpettacolo, descrizione, durata, genere, regista, anno )
PARTECIPAZIONE ( codAttore: ATTORE, codSpettacolo: SPETTACOLO, ruolo )
RAPPRESENTAZIONE ( codSpettacolo: SPETTACOLO, data, numeroSpettatori)

Scrivere una query SQL che visualizzi, per ciascuno spettacolo, la data di rappresentazione che ha avuto
il maggior numero di spettatori (codSpettacolo, data, numeroSpettatori).

A me viene da scrivere questa soluzione:
SELECT codSpettacolo, data, numeroSpettatori
FROM RAPPRESENTAZIONE
WHERE numeroSpettatori = (SELECT MAX(numeroSpettatori)
FROM RAPPRESENTAZIONE)

Breve spiegazione:
SELECT codSpettacolo, data, numeroSpettatori
FROM RAPPRESENTAZIONE
mi crea una tabella con tutte le rappresentazioni, io ne voglio solo una, quella con il numero massimo di spettatori, quindi metto una condizione where che dice di prendere quella che ha
numeroSpettatori = (SELECT MAX(numeroSpettatori)
FROM RAPPRESENTAZIONE)
così mi sceglie la tupla con il max numero spettatori dalla tabella di tutte le rappresentazioni.


So che questo ragionamento è sbagliato perchè la soluzione presa dal vecchio testo d'esame è quella riportata di seguito allora vi chiedo dove è sbagliato il mio ragionamento:

SELECT codSpettacolo, data, numeroSpettatori
FROM RAPPRESENTAZIONE R
WHERE numeroSpettatori = (SELECT MAX(numeroSpettatori)
FROM RAPPRESENTAZIONE R1
WHERE R.codSpettacolo = R1.codSpettacolo)


Grazie.

gugoXX
01-12-2008, 18:37
Tu stai risolvendo la

selezionare la rappresentazione che ha avuto
il maggior numero di spettatori (codSpettacolo, data, numeroSpettatori).

(In realta' le rapprensentazioni che hanno avuto come numero di spettatori il massimo numero di spettatori mai avuto, che possono essere piu' di una)

mentre invece dovevi risolvere la
Enunciare per ciascuno spettacolo, la data di rappresentazione che ha avuto
il maggior numero di spettatori (codSpettacolo, data, numeroSpettatori).

Ovvero, se uno spettacolo ha avuto 3 rappresentazioni, ciascuna delle quali avente 15, 35, 10 spettatori, la rappresentazione con 35 spettatori la devi tirare fuori, anche se c'e' stato un altra rappresentazione (di un altro spettacolo) avente 50 spettatori.

-Ivan-
01-12-2008, 18:44
Tu stai risolvendo la

selezionare la rappresentazione che ha avuto
il maggior numero di spettatori (codSpettacolo, data, numeroSpettatori).

(In realta' le rapprensentazioni che hanno avuto come numero di spettatori il massimo numero di spettatori mai avuto, che possono essere piu' di una)

mentre invece dovevi risolvere la
Enunciare per ciascuno spettacolo, la data di rappresentazione che ha avuto
il maggior numero di spettatori (codSpettacolo, data, numeroSpettatori).

Ovvero, se uno spettacolo ha avuto 3 rappresentazioni, ciascuna delle quali avente 15, 35, 10 spettatori, la rappresentazione con 35 spettatori la devi tirare fuori, anche se c'e' stato un altra rappresentazione (di un altro spettacolo) avente 50 spettatori.

:doh: Ma porca ecco perchè non mi tornava, avevo letto malissimo la consegna. Grazie adesso ci sono arrivato...:D