|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1843
|
[SQL] Mi è andato in panne il cervellino...
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. |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
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.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto. E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test. |
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Mar 2003
Città: Rimini
Messaggi: 1843
|
Quote:
Ma porca ecco perchè non mi tornava, avevo letto malissimo la consegna. Grazie adesso ci sono arrivato... |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 01:21.












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








