Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
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: 11769
[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: 11769
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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
L'intelligenza artificiale ha reso pi&ug...
L'intelligenza artificiale per lo svilup...
Il sistema di verifica dell'identit&agra...
Ora è ufficiale: Samsung sta per ...
Motorola Edge 70 Fusion: ecco le specifi...
8TB a meno di 170€: il richiestissimo Ha...
Il nuovo MacBook 'low cost' arriver&agra...
Pokémon Rosso Fuoco e Verde Fogli...
Risparmiare con le offerte Amazon: weeke...
Gli Xiaomi 17 arrivano a fine febbraio, ...
48.000 Pa a poco più di 100€: la ...
PC più potente, meno spesa: su Amazon to...
Con 2 acquisti si ottiene il 40% di scon...
Blocco VPN in Spagna durante le partite ...
ECOVACS DEEBOT T30C OMNI GEN2 torna a 34...
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: 04:09.


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