Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 23-08-2006, 11:34   #1
prazision
Senior Member
 
L'Avatar di prazision
 
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.
prazision è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 12:17   #2
ally
Bannato
 
L'Avatar di ally
 
Iscritto dal: Jan 2003
Città:
Messaggi: 4421
...prova con un SELECT DISTINCT telefono,nome FROM tabella WHERE ... GROUP BY telefono...

...ciao...
ally è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 13:39   #3
aldonation
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
aldonation è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 13:45   #4
mailand
Senior Member
 
L'Avatar di mailand
 
Iscritto dal: Aug 2001
Città: milano, qualunque birreria
Messaggi: 4208
Quote:
Originariamente inviato da aldonation
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)
__________________
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.
mailand è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 13:57   #5
prazision
Senior Member
 
L'Avatar di prazision
 
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.
prazision è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 14:08   #6
aldonation
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...
aldonation è offline   Rispondi citando il messaggio o parte di esso
Old 23-08-2006, 14:19   #7
prazision
Senior Member
 
L'Avatar di prazision
 
Iscritto dal: Dec 2003
Messaggi: 458
Quote:
Originariamente inviato da aldonation
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
prazision è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
Elgato Embrace: una sedia ergonomica pro...
Brad Pitt torna in pista: F1 – Il Film a...
Hitachi Vantara annuncia la sua AI Facto...
Brembo passa all'alluminio riciclato al ...
HONOR pronta a sfidare gli iPad Pro con ...
OpenAI esce allo scoperto: confermati i ...
In arrivo altri due prodotti da Apple en...
Il tool per aggiornare da Windows 10 a W...
Rishi Sunak entra in Microsoft e Anthrop...
Porsche in poche ore chiude la formazion...
iPhone 17 disponibili su Amazon al prezz...
La Ferrari Elettrica non è la cau...
Ricarica da record: Zeekr supera i 1.300...
Un 'capezzolo' con feedback aptico al po...
Porsche Taycan Rush a Misano: prima al v...
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: 20:02.


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