|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Junior Member
Iscritto dal: Apr 2008
Messaggi: 6
|
[SQL] una query
ciao a tutti!
Ho un problema con una query di sql, e spero che qualcuno di voi possa darmi una mano La query in questione è la seguente: "trovare per ogni marca il modello più venduto" considerando di avere le seguinti tabelle: VETTURA(CODICE,MODELLO) MARCA (CODICE,NOME) MODELLO(CODICE, NOME, MARCA) VENDITE_EFFETTUATE(DATA_VENDITA, IMPIEGATO,CLIENTE,VETTURA) Non ho messo le tabelle di impiegato e cliente, tanto sono inutili per questa query. Considerando che in Modello l'attributo Marca fa riferimento al Codice della Marca e in Vendite_Effettuate l'attributo Vettura fa riferimento al codice della Vettura. Ora sono arrivato a scrivere questo codice,solo che non capisco come vedere i massimi ...SELECT MODELLO.NOME, MARCA.NOME,COUNT(MODELLO.NOME) FROM VETTURA, MODELLO, MARCA WHERE VETTURA.CODICE IN ( SELECT VENDITE_EFFETTUATE.VETTURA FROM VENDITE_EFFETTUATE) AND VETTURA.MODELLO=MODELLO.CODICE AND MARCA.CODICE=MODELLO.MARCA GROUP BY MODELLO.NOME; A questo punto mi viene una tabella di questo tipo: +--------------------------------------------+ | NOME | NOME | COUNT(MODELLO.NOME) | +--------+--------+--------------------------+ | PUNTO | FIAT | 3 | | BRAVA | FIAT | 1 | | 206 | PEUGEOT | 2 | | 207 | PEUGEOT | 5 | +--------+----------+------------------------+ Ora come faccio a dirgli che la Punto è il modello più venduto della Fiat e la 207 il più venduto della Peogeut |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Innanzitutto un consiglio.
Mi sembra che tu abbia usato un Database come MySql, essendo che stai facendo (e magari sei anche riuscito a fare) una Query di raggruppamento con i termini in GROUP BY che sono meno di quelli della SELECT, che viene permesso solo (da quanto ne so) da MySQL. Questo non e' SQL Standard, e non si capisce neppure bene cosa debba venire fuori, quindi ti sconsiglio di usarlo in futuro. Partendo dal presupposto che "piu' venduto" sia basato sul numero di vendite Provo a mettere qui di seguito il ragionamento. E' una query unica. 1. trovare il conteggio di vetture per modello Codice:
SELECT vettura,COUNT(*) cnt FROM vendite GROUP BY vettura Codice:
SELECT vettura,MAX(cnt) cntmax FROM (la query di prima) GROUP BY vettura E' imprecisa perche' non essendoci il disegno E-R non si capisce quali siano i codici e dove puntino. Ma il concetto e' simile. Codice:
SELECT * FROM (la query di prima) qry JOIN vettura ON (qry.vettura=vettura.codice) JOIN modello ON (qry.vettura=modello.codice) JOIN marca ON (qry.vettura=marca.codice)
__________________
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: May 2005
Città: Napoli - Fuorigrotta
Messaggi: 471
|
Quote:
Guarda questa query: Codice:
SELECT count(descr) as cnt, utente, descr FROM sts_dbms.log GROUP BY utente,descr Codice:
SELECT count(descr) as cnt, utente, descr FROM sts_dbms.log GROUP BY utente
__________________
Acquisti sul mercatino: grabrihc, LucaXbox360, Yarsha,micanto1,American horizo,Fnac,schumyFast,STECCO,Ezechiele25,17 Vendite sul mercatino: musodatopo,alexbands,mspr,anto.wajo |
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
|
Grazie per la specifica
Rileggendo sopra nelle prime due query ho scritto "Vettura". Ovviamente dovevo scrivere "Modello", essendo il tuo ragionamento basato tutto sul modello. Per come sono messe le tabelle e' piu' complesso da ottenere.
__________________
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. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:03.










...









