Torna indietro   Hardware Upgrade Forum > Software > Programmazione

DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica
Il nuovo gimbal mobile DJI evolve il concetto di tracciamento automatico con tre modalità diverse, un modulo multifunzionale con illuminazione integrata e controlli gestuali avanzati. Nel gimbal è anche presente un'asta telescopica da 215 mm con treppiede integrato, per un prodotto completo per content creator di ogni livello
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce
Abbiamo provato il nuovo HUAWEI Pura 80 Pro. Parliamo di uno smartphone che è un vero capolavoro di fotografia mobile, grazie ad un comparto completo in tutto e per tutto, In questa colorazione ci è piaciuto molto, ma i limiti hardware e software, seppur in netto miglioramento, ci sono ancora. Ma HUAWEI ha fatto davvero passi da gigante per questa nuova serie Pura 80. Buona anche l'autonomia e soprattutto la ricarica rapida sia cablata che wireless, velocissima.
Opera Neon: il browser AI agentico di nuova generazione
Opera Neon: il browser AI agentico di nuova generazione
Abbiamo provato il nuovo web browser con intelligenza artificiale della serie Opera accessibile tramite abbonamento. Ecco le nostre prime impressioni sulle funzionalità di Opera Neon basate su AI e come funzionano
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2008, 12:25   #1
Rubberick
Senior Member
 
L'Avatar di Rubberick
 
Iscritto dal: Nov 2002
Messaggi: 11745
[SQL] Query con GROUP BY + ORDER BY :D

Ciao ragazzi, ho un piccolo problemino con una query, vediamo se potete aiutarmi...

ho 2 tabelle organizzate cosi'

id | nome | desc

id | last_up_time | valore1 | valore2

vorrei fare una query dove ottengo id, nome, desc...

fino e qui avrei un banale

Quote:
SELECT * FROM table1
tuttavia vorrei ottenere in una sola query anche i valori di table2 ordinati per tempo

Quote:
SELECT * FROM table1 LEFT JOIN table2 ON (table1.id = table2.id) ORDER BY table2.last_up_time DESC
molto bene ci siamo quasi... unico problema... vorrei non avere ripetizioni...

cioe' in table 2 ci saranno molti valori con lo stesso id, in quanto la chiave primaria e' il tempo di aggiornamento che e' sempre diverso...

a me interessa ottenere un unica riga di table2 dove il tempo sia il + aggiornato =) non mi interessano tutte le altre righe con tempo vecchio

ho provato ad usare group by table1.id ma non funziona =|, cioe' mi vengono restituiti tutti i dati come li vorrei solo che l'ordinamento e' fatto in seguito... non prima di gruppare =|, le righe hanno il campo time che vogliono loro non l'ultimo aggiornamento =(

Quote:
SELECT * FROM table1 LEFT JOIN table2 ON (table1.id = table2.id) GROUP BY table1.id ORDER BY table2.last_up_time DESC
Io avrei bisogno di invertire concettualmente l'ordinamento e poi il group ma mysql mi da errore... come posso fare? dove sbaglio?
__________________
Ho fatto affari con: troppi per elencarli

Vendo: NAS PRO QNAP 4 BAIE 419P+ CON LCD
Rubberick è offline   Rispondi citando il messaggio o parte di esso
Old 16-02-2008, 12:53   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
In SQL standard si puo' fare, ma solo con una autojoin
Il problema e' anche solo limitabile alla tabella2, ovvero:
Vorrei ottenere un risultato tipo:
id | last_up_time | valore1 | valore2
ma con solo i valori piu' aggiornati, per ciascun id.

Quanto segue suppone che la chiave primaria della tabella2 sia esattamente (id, last_up_time )

Per poterlo fare in SQL-92 standard occorrono 2 passi:
per ciascun ID cerco qual e' il last_up_time maggiore, scrivendo la subquery relativa
Metto in join la subquery ottenuta con la tabella orignale, filtrando i record interessati.
Si chiama autojoin perche' la tabella in questione e' referenziata due volte.

Per questo esempio la subquery sarebbe
SELECT id,max(last_up_time) max_last_up_time
FROM tabella 2
GROUP BY id

mentre la query completa sarebbe
Codice:
SELECT tabella2.*
FROM tabella2
JOIN (SELECT id,max(last_up_time) max_last_up_time 
         FROM tabella 2         
         GROUP BY id) AS subq
ON (tabella2.ID=subq.ID AND tabella2.last_up_time=subq.max_last_up_time)
Se poi hai bisogno di altre informazioni della tabella1, a questo punto potrai fare un JOIN secco, senza porti piu' problemi di distinct o altro, in quanto per costruzione la SELECT precedente avra' una e una sola riga per ciascun ID, con proprio i dati che stai cercando (ovvero quelli della data piu' recente).

Per risolvere tale limite dell'SQL, per un problema tutt'altro che raro, le singole implementazioni hanno dotato il loro motore di soluzioni diverse.

Oracle: Funzioni analitiche, inserite dal 8.1.6.2
SQL-Server 2000: Mix di TOP e ORDER BY. Non risolve completamente l'auto-Join
SQL-Server 2005: Funzioni analitiche (limitate).
My-Sql: So che esiste anche qui il TOP (mi sembra si chiami LIMIT). Non so se si puo' usare all'interno di subquery e insieme a ORDER BY. Se si potesse sarebbe la stessa soluzione di SQLServer 2000

In sostanza: Prova con la soluzione standard. Se poi non ti piace studia la LIMIT con ORDER BY.

C'e' ancora una soluzione possibile, relativamente ad una estensione del SQL standard che si chiama "INLINE Query", che pero' e' praticabile solamente se il numero di colonne come le tue valore1, valore2,... valoren e' esattamente uguale ad 1, altrimenti fa pena.
Nel tuo caso e' gia' 2, pertanto non va bene.
Non so neppure se funziona sotto mysql

Codice:
SELECT ttt.id,
           max( ttt.last_up_time ) max_last_up_time,
           (SELECT valore1
               FROM tabella2 tint
               WHERE tint.id=ttt.id AND tint.last_up_time=max_last_up_time) valore1
         FROM tabella2  ttt       
         GROUP BY id
In pratica le INLINE Query sono funzioni scalari, che devono quindi restitirue una sola riga e una sola colonna, e che possono essere calcolate in funzione di parametri della query esterna.
Ma anche in questo caso come vedi si referenzia 2 volte la tabella originale.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.

Ultima modifica di gugoXX : 16-02-2008 alle 13:14. Motivo: Inline Query, non Inline Function
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 12:22   #3
Rubberick
Senior Member
 
L'Avatar di Rubberick
 
Iscritto dal: Nov 2002
Messaggi: 11745
Grazie sei stato chiarissimo =) ci sono riuscito con la prima soluzione
__________________
Ho fatto affari con: troppi per elencarli

Vendo: NAS PRO QNAP 4 BAIE 419P+ CON LCD
Rubberick è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 12:36   #4
francescosalvaggio
Senior Member
 
Iscritto dal: Dec 2005
Città: Toscana
Messaggi: 1196
altrimenti non puoi usare il costrutto DISTINCT per evitare le ripetizioni
francescosalvaggio è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 12:39   #5
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Non direi, la tabella2 ha righe tutte diverse, non ci sono ripetizioni.
Puoi provare a spiegarti meglio?
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 14:13   #6
francescosalvaggio
Senior Member
 
Iscritto dal: Dec 2005
Città: Toscana
Messaggi: 1196
SELECT DISTINCT attributo
FROM tabella/e

la distinct si fa sull'attributo della select che ti frega se hai più tabelle... non avevi detto che non volevi eliminare i risultati doppi ?
francescosalvaggio è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 14:16   #7
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Mi sa che non hai letto bene il problema.
Lui ha una tabella
id | last_up_time | valore1 | valore2

Dove ID e' ripetuto tante volte, per degli istanti diversi.

Vuole avere una query che restituisca, per ciascun ID, quale e' il record con la data piu' grande, e quali sono i due relativi campi valore1 e valore2
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
Recensione Pura 80 Pro: HUAWEI torna a stupire con foto spettacolari e ricarica superveloce Recensione Pura 80 Pro: HUAWEI torna a stupire c...
Opera Neon: il browser AI agentico di nuova generazione Opera Neon: il browser AI agentico di nuova gene...
Wind Tre 'accende' il 5G Standalone in Italia: si apre una nuova era basata sui servizi Wind Tre 'accende' il 5G Standalone in Italia: s...
OPPO Find X9 Pro: il camera phone con teleobiettivo da 200MP e batteria da 7500 mAh OPPO Find X9 Pro: il camera phone con teleobiett...
1.200 CV e drift a 213 km/h: la supercar...
Shenzhou-21: esperimenti sui topi in orb...
Cloudera punta su cloud privato e intell...
Il mistero del Ryzen 7 9700X3D: prezzo p...
Posticipato il rientro dell'equipaggio c...
Propaganda russa e hactivism fra le prin...
Superluna del Castoro: stasera il satell...
NVIDIA regala una GeForce RTX 5090 Found...
Snowflake punta su Intelligence, l'IA pe...
Volkswagen realizzerà i propri chip per ...
Formula E GEN4 svelata: 600 kW di potenz...
PC Desktop HP Victus con RTX 4060 e Ryze...
Fastnet, il 'mega-cavo' di AWS che pu&og...
Offerte Amazon da non perdere: GeForce R...
Clima, l'UE trova l'accordo sul taglio d...
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: 06:41.


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