PDA

View Full Version : [sql] mysql: distinct su un campo solo


prazision
23-08-2006, 11:34
utilizzo una vecchia versione di mysql (mi pare 4.0.18) e ho un problema:

la mia tabella utente contiene: id, nome, cognome, telefono, ecc.

per motivi che non sto a spiegare si potrebbe verificare un simile caso:

row 1:carlo, rossi, 02-44556677
row 2:carlo massimo, rossi, 02-44556677

facendo un distinct in questa maniera:
select distinct telefono, nome, cognome from utente
ottengo entrambe le righe (perchè varia il nome)

mentre facendo:
select distinct telefono from utente
ottengo una sola riga

a me servirebbe di ottenere cmq solo 1 riga (è indifferente quale) perchè il numero di telefono è lo stesso; insomma dovrei in qualche maniera fare un distinct sul telefono che però mi tiri fuori anche gli altri dati

come faccio???(non posso usare le query annidate per via della versione di mysql)

grazie

ally
23-08-2006, 12:17
...prova con un SELECT DISTINCT telefono,nome FROM tabella WHERE ... GROUP BY telefono...

...ciao...

aldonation
23-08-2006, 13:39
Non se se in mysql funziona visto che ho provato solo in MSSQL...
Io farei un:
SELECT MAX(nome), MAX(cognome), telefono FROM tabella GROUP BY telefono

Ripeto che non so se mysql ti fa fare il max su qualcosa che non sia numerico...

Ciao :)

mailand
23-08-2006, 13:45
Non se se in mysql funziona visto che ho provato solo in MSSQL...
Io farei un:
SELECT MAX(nome), MAX(cognome), telefono FROM tabella GROUP BY telefono

Ripeto che non so se mysql ti fa fare il max su qualcosa che non sia numerico...

Ciao :)
così però il risultato non è deterministico, una o più combinazioni sarebbero perse. meglio la distinct dei 2 campi, in questo caso secondo me la group by è inutile perchè non hai una somma.
in alternativa, si potrebbe fare una roba simile:

select telefono, count(*) from tabella group by telefono

in questo modo vedi i singoli numeri telefonici e le relative occorrenze (conta le righe relative ad ogni elemento membro della group by)

edit: usando la query con questa sintassi:

select telefono, count(*) from tabella group by telefono having count(*)>1

vedi solo le occorrenze che hanno più di una riga (spero che funzioni in mysql)

prazision
23-08-2006, 13:57
EDIT:
ma scusate A ME QUESTA SOLUZIONE sembra funzionare:
SELECT nome, cognome, telefono FROM tabella GROUP BY telefono

no?

se sì agiungo: non posso fare un order by all'interno del group by??
insomma al posto di fargli tirare fuori una riga a caso fargli prendere
magari quella con la data di nascita più recente??
se metto order by data alla fine della query ordina per data ma sulle
righe alle quali è già stata applicata la group by e quindi non funziona

grazie

aldonation
23-08-2006, 14:08
Se SELECT nome, cognome, telefono FROM tabella GROUP BY telefono funziona su mysql vuol dire che è un po' fuori dagli standard...non ho quindi idea di cosa restituisca...per il resto se non puoi usare sottoquery la vedo dura ordinare i dati nel modo in cui vorresti...

prazision
23-08-2006, 14:19
Se SELECT nome, cognome, telefono FROM tabella GROUP BY telefono funziona su mysql vuol dire che è un po' fuori dagli standard...non ho quindi idea di cosa restituisca....

effettivamente penso sia fuori dagli standard