Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi
Con un prezzo di 2.999 euro, il Panasonic Z95BEG entra nella fascia ultra-premium dei TV OLED: pannello Primary RGB Tandem, sistema di raffreddamento ThermalFlow, audio Technics integrato e funzioni gaming avanzate lo pongono come un punto di riferimento
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-02-2008, 11: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, 11: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 12:14. Motivo: Inline Query, non Inline Function
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 17-02-2008, 11: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, 11: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, 11: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, 13: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, 13: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


Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Recensione Google Pixel 10 Pro XL: uno zoom 100x assurdo sempre in tasca (e molto altro) Recensione Google Pixel 10 Pro XL: uno zoom 100x...
La sorpresa di IAA Mobility è Xyt...
Le vetture elettriche Opel GSE: Mokka GS...
Star Wars: Knight of the Old Republic Re...
Scoperta un'enorme rete IPTV da pi&ugrav...
Anche Life is Strange diventerà u...
QSAN presenta la nuova serie XN1 di NAS ...
Abbiamo visto in anteprima nuova Renault...
Come ricaricare i veicoli elettrici sino...
Microsoft annuncia nuovi servizi azienda...
Roborock QV 35S spazza via lo sporco: po...
The Last of Us: arriva il primo Emmy per...
Firefox abbandona Linux a 32 bit: fine d...
Reti mobili italiane: chi vince e chi pe...
God of War: le riprese della serie TV ta...
Volkswagen ID. Cross Concept: design Pur...
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: 01:12.


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