|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Senior Member
Iscritto dal: Dec 2003
Messaggi: 458
|
[sql] mysql: distinct su un campo solo
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 Ultima modifica di prazision : 23-08-2006 alle 11:36. |
![]() |
![]() |
![]() |
#2 |
Bannato
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
|
...prova con un SELECT DISTINCT telefono,nome FROM tabella WHERE ... GROUP BY telefono...
...ciao... |
![]() |
![]() |
![]() |
#3 |
Member
Iscritto dal: Aug 2006
Messaggi: 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 ![]() |
![]() |
![]() |
![]() |
#4 | |
Senior Member
Iscritto dal: Aug 2001
Città: milano, qualunque birreria
Messaggi: 4208
|
Quote:
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)
__________________
Save water: drink beer.
This message has been created with 100% recycled electrons Un rutto vale più di mille parole. Ultima modifica di mailand : 23-08-2006 alle 13:47. |
|
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Dec 2003
Messaggi: 458
|
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 Ultima modifica di prazision : 23-08-2006 alle 14:00. |
![]() |
![]() |
![]() |
#6 |
Member
Iscritto dal: Aug 2006
Messaggi: 39
|
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...
|
![]() |
![]() |
![]() |
#7 | |
Senior Member
Iscritto dal: Dec 2003
Messaggi: 458
|
Quote:
|
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 20:02.