-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.
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.