PDA

View Full Version : [MYSQL] Richiesta chiarimenti su interrogazioni DB


PaVi90
19-06-2009, 14:26
Salve ragazzi,
chi mi spiega a livelli "da asilo" le funzioni di:
- GROUP BY (se ho capito bene serve ad ordinare il risultato della query in base ad un campo);
- HAVING (che differenza intercorre col WHERE?)
- ORDER BY (che differenza intercorre col GROUP BY?)

Grazie mille! :)

john_revelator
19-06-2009, 14:38
Ci provo. ;)
L'order by serve per specificare l'ordine in cui vuoi che ti vengano restituiti i record. Quindi se li vuoi in ordine alfabetico rispetto ad un campo scrivi

select * from tabella order by nome_campo

di default l'ordinamento è crescente (asc) e quindi non è necessario specificarlo mentre se vuoi ottenere l'ordinamento decrescente usi desc (..order by nome_campo desc).

Ovviamente è possibile specificare l'ordinamento su più campi. Se ad esempio scrivi:

select * from tabella order by cognome,nome

i record verranno ordinati in senso crescente per cognome, e a parità di cognome, in ordine crescente di nome.

Il group by invece serve per ragguppare i record in base a uno o più campi.

Ti faccio un esempio banale

id tipo prezzo
1 1 10
2 1 5
3 2 2
4 2 4


se vuoi ottenere il totale dei prezzi raggruppando per tipo scriverai

select tipo,sum(prezzo) as totale
from tabella
group by tipo

e otterrai

tipo totale
1 15
2 6

per rispondere alla tua ultima domanda mi rifaccio all'esempio precedente.
Supponiamo tu voglia conoscere i tipi il cui totale è maggiore di 10

In questo caso non puoi usare il where ma usi l'having che interviene una volta che il raggruppamento è già stato fatto e quindi la tua query sarebbe

select tipo,sum(prezzo) as totale
from tabella
group by tipo
having totale > 10

La sintassi che ho usato è quella di mysql ma grosso modo è analoga in tutti i rdbms. :)

PaVi90
19-06-2009, 14:43
Grazie mille; sei stato chiarissimo!! :ave:

Domanda: l'HAVING va quindi SOLO col GROUP BY in sostituzione del WHERE?

Seconda domandina: nel secondo esempio (group by) se anzichè scrivere:

select tipo,sum(prezzo) as totale
from tabella
group by tipo

scrivessi:

select tipo,sum(prezzo) as totale
from tabella
order by tipo

Funzionerebbe ugualmente?

john_revelator
19-06-2009, 14:53
Grazie mille; sei stato chiarissimo!! :ave:

Un'ultima domanda: l'HAVING va quindi SOLO col GROUP BY in sostituzione del WHERE?

L'having va sempre usato dopo il group by ma può anche essere usato in combinazione con il where. Come ti accennavo prima l'having lo usi per limitare l'estrazione dei record in base a qualche parametro di aggregazione che ricavi dopo che il raggruppamento è avvenuto. Ti faccio un altro esempio

id nome punteggio
1 nicola 10
2 nicola 2
3 andrea 4
4 andrea 3
5 giovanni 10
6 giovanni 10

Supponiamo tu voglia conoscere i nomi delle persone che hanno almeno un totale di 10 punti ma il cui nome sia solo nicola o andrea.

In questo caso la tua query diventa


select nome,sum(punteggio) as totale
from tabella
where nome in ('andrea','nicola')
group by nome
having totale >= 10


In pratica con il where limiti la ricerca a quei due nomi mentre per sapere quelli che hanno punteggio pari almeno a 10 usi l'having alla fine e quindi ottieni come risultato solo nicola con un totale di 12.

In teoria potresti anche riscrivere la query così



select nome,sum(punteggio) as totale
from tabella
group by nome
having totale >= 10 and nome in ('andrea','nicola')


e otterresti comunque la stessa cosa.
Spero di aver reso l'idea. :)

john_revelator
19-06-2009, 14:58
Grazie mille; sei stato chiarissimo!! :ave:
Seconda domandina: nel secondo esempio (group by) se anzichè scrivere:

select tipo,sum(prezzo) as totale
from tabella
group by tipo

scrivessi:

select tipo,sum(prezzo) as totale
from tabella
order by tipo

Funzionerebbe ugualmente?

No, non funzionerebbe.
Potresti solo scrivere

select sum(prezzo) as totale from tabella

per ottenere il totale della tabella ma per raggruppare per nominativo è necessario usare il group by.
Nessuno ti impedisce una volta effettuato il raggruppamento di ordinare come ti pare


select tipo,sum(prezzo) as totale
from tabella
group by tipo
order by tipo

PaVi90
19-06-2009, 14:58
Ottimo, ora mi è chiarissimo. Grazie ancora!! :)

Magari il mio prof di informatica spiegasse come te... ora non mi ritroverei con il patema d'animo una settimana prima degli esami :stordita:

john_revelator
19-06-2009, 15:09
Prego.... e in bocca al lupo per gli esami. ;)

PaVi90
19-06-2009, 15:14
Crepi! :D