Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-06-2009, 15:26   #1
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
[MYSQL] Richiesta chiarimenti su interrogazioni DB

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!
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 15:38   #2
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
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.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 15:43   #3
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Grazie mille; sei stato chiarissimo!!

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?

Ultima modifica di PaVi90 : 19-06-2009 alle 15:51.
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 15:53   #4
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Quote:
Originariamente inviato da PaVi90 Guarda i messaggi
Grazie mille; sei stato chiarissimo!!

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

Codice:
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ì

Codice:
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 è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 15:58   #5
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Quote:
Originariamente inviato da PaVi90 Guarda i messaggi
Grazie mille; sei stato chiarissimo!!
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

Codice:
select tipo,sum(prezzo) as totale
from tabella
group by tipo
order by tipo
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 15:58   #6
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
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
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 16:09   #7
john_revelator
Senior Member
 
L'Avatar di john_revelator
 
Iscritto dal: Jul 2007
Messaggi: 1092
Prego.... e in bocca al lupo per gli esami.
john_revelator è offline   Rispondi citando il messaggio o parte di esso
Old 19-06-2009, 16:14   #8
PaVi90
Bannato
 
Iscritto dal: May 2007
Città: Vivo in un mondo in cui tutti ti accusano e ti additano per un nonulla...
Messaggi: 9995
Crepi!
PaVi90 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
La Cina lancia un servizio simile a Dire...
SpaceX: Elon Musk torna a parlare dei pr...
G.Skill risarcisce 2,4 milioni di dollar...
Test degli annunci su ChatGPT avviati: '...
TSMC approva investimenti record da quas...
L'IA agentica arriva anche sullo storage...
Euro digitale, il Parlamento UE cambia r...
Alphabet e la sua obbligazione centenari...
L'UE anticipa un intervento per bloccare...
Il Trump Phone esiste ma è molto ...
Frodi deepfake fuori controllo: perch&ea...
Consumano il 30% in meno: arrivano i nuo...
Tesla Semi svela i numeri definitivi: 80...
La Air Force statunitense vieta occhiali...
Wi-Fi Intel e Windows: le novità ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 23:52.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v