Torna indietro   Hardware Upgrade Forum > Software > Programmazione

ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz
ASUS ROG Swift OLED PG34WCDN è il primo monitor gaming con pannello QD-OLED Gen 5 a layout RGB Stripe Pixel e 360 Hz su 34 pollici: lo abbiamo misurato con sonde colorimetriche e NVIDIA LDAT. Ecco tutti i dati
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-12-2012, 14:44   #1
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
[SQL] Prestazioni di una query annidata

Il mio dubbio è su questa piccola query:

Codice:
SELECT *
FROM MATCHES 
WHERE UPDATE_TIME > 
      (SELECT UPDATE_TIME 
      FROM SESSIONS 
      WHERE NOT UPDATED AND SID = 'abc')
La query si ferma se la query annidata ritorna un recordset vuoto? Non vorrei che andasse ad aprirmi la tabella MATCHES senza essercene bisogno!

Cambiando l'ordine delle condizioni
Quote:
WHERE AND SID = 'abc' AND NOT UPDATED
Si ottiene un vantaggio dal punto di vista prestazionale ?

Magari ipotizzando che SID è un indice univoco a 32 caratteri e più o meno una sessione su due ha UPDATED fissato a FALSE.

Grazie mille a chi si interesserà! Preciso che il dbms è apache derby, ma immagino sia poco influente visto che la gestione dovrebbe essere bene o male simile per tutti i dbms.
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 14:52   #2
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Il mio dubbio è su questa piccola query:

Codice:
SELECT *
FROM MATCHES 
WHERE UPDATE_TIME > 
      (SELECT UPDATE_TIME 
      FROM SESSIONS 
      WHERE NOT UPDATED AND SID = 'abc')
La query si ferma se la query annidata ritorna un recordset vuoto? Non vorrei che andasse ad aprirmi la tabella MATCHES senza essercene bisogno!

Cambiando l'ordine delle condizioni


Si ottiene un vantaggio dal punto di vista prestazionale ?

Magari ipotizzando che SID è un indice univoco a 32 caratteri e più o meno una sessione su due ha UPDATED fissato a FALSE.

Grazie mille a chi si interesserà! Preciso che il dbms è apache derby, ma immagino sia poco influente visto che la gestione dovrebbe essere bene o male simile per tutti i dbms.
più che altro è quel * a fare cose che non sono nesessarie (occupare cpu/ram).
Sempre meglio specificare i campi necessari.

P.S ma recordset vuote è = 0?
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 14:58   #3
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
più che altro è quel * a fare cose che non sono nesessarie (occupare cpu/ram).
Sempre meglio specificare i campi necessari.

P.S ma recordset vuote è = 0?
Ho messo il * perchè mi servono veramente tutti i campi, dal primo all'ultimo.

Con recordSet vuoto intendo:
Codice:
      (SELECT UPDATE_TIME 
      FROM SESSIONS 
      WHERE NOT UPDATED AND SID = 'abc')
che non torna nessun risultato! 0 record. La prima select select vedrebbe UPDATE_TIME > [qualcosa che non so come venga interpretato (recordset vuoto)] e non so come si comporti.

Dato che deve essere chiamata centinaia di volte al minuto, è indispensabile che dopo che il select interno non abbia prodotto risultati la query si fermi là e lasci stare l'altra tabella, che è anche piuttosto grande.
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 15:14   #4
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Ho messo il * perchè mi servono veramente tutti i campi, dal primo all'ultimo.

Con recordSet vuoto intendo:
Codice:
      (SELECT UPDATE_TIME 
      FROM SESSIONS 
      WHERE NOT UPDATED AND SID = 'abc')
che non torna nessun risultato! 0 record. La prima select select vedrebbe UPDATE_TIME > [qualcosa che non so come venga interpretato (recordset vuoto)] e non so come si comporti.

Dato che deve essere chiamata centinaia di volte al minuto, è indispensabile che dopo che il select interno non abbia prodotto risultati la query si fermi là e lasci stare l'altra tabella, che è anche piuttosto grande.
quello che mi domandavo anche io.
Fai una prova con qualcosa che sai essere vuoto e vedi come si comporta e in base a quello ti regoli, no?
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 15:19   #5
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
ripensandoci.
(*) (SELECT UPDATE_TIME
FROM SESSIONS
WHERE NOT UPDATED AND SID = 'abc')

Se la (*) ha un risultato è ok.
Se ne ha 0 ti restituisce NULL e quindi scazza.
Se hai + di un risultato sei finito e schianti il DB.

Gli operatori > e < sono binari alla fine.

Che db usi, tanto per sapere.
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 15:45   #6
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Il mio dubbio è su questa piccola query:

Codice:
SELECT *
FROM MATCHES 
WHERE UPDATE_TIME > 
      (SELECT UPDATE_TIME 
      FROM SESSIONS 
      WHERE NOT UPDATED AND SID = 'abc')
La query si ferma se la query annidata ritorna un recordset vuoto? Non vorrei che andasse ad aprirmi la tabella MATCHES senza essercene bisogno!

Cambiando l'ordine delle condizioni


Si ottiene un vantaggio dal punto di vista prestazionale ?

Magari ipotizzando che SID è un indice univoco a 32 caratteri e più o meno una sessione su due ha UPDATED fissato a FALSE.

Grazie mille a chi si interesserà! Preciso che il dbms è apache derby, ma immagino sia poco influente visto che la gestione dovrebbe essere bene o male simile per tutti i dbms.
Se la subquery ritorna il vuoto la where della select principale è impossibile quindi non viene eseguita e ha costo 0.

L'ordine degli operandi non importa ci pensa il db a scegliere l'ordine migliore in base agli indici che ha a disposizione.
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 17:26   #7
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Perfetto, quindi la query non ha problemi, il dbms

The_ouroboros: una query senza risultati non restituisce null !

Nel caso torni più di un risultato (cosa impossibile, pura curiosità) il dbms come si comporta, va in errore immagino.

Ah, uso apache derby, come scritto nel primo post!

Grazie!
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 17:28   #8
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi

The_ouroboros: una query senza risultati non restituisce null !


Grazie!
Ne sei sicuro?



Inviato dal mio HUAWEI U8825-1 con Tapatalk 2
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 20:39   #9
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
Ne sei sicuro?
Eh si, l'ha detto VICIUS e del resto è anche prevedibile che doveva essere così (del resto NULL è ben diverso dall'insieme vuoto).
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 04-12-2012, 20:52   #10
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da cicciopasticcio1 Guarda i messaggi
Eh si, l'ha detto VICIUS e del resto è anche prevedibile che doveva essere così (del resto NULL è ben diverso dall'insieme vuoto).
ha detto che è impossibile non che non è NULL
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2012, 01:40   #11
cicciopasticcio1
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 22
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
ha detto che è impossibile non che non è NULL
No, ha detto che la query principale è impossibile dal momento che la subquery torna un vuoto

(da quanto ho capito) anche se la subquery tornasse un NULL (non è il nostro caso) la query principale sarebbe impossibile dato che (leggendo questa pagina http://en.wikipedia.org/wiki/Null_%28SQL%29) la condizione INT > NULL non si verifica mai.
cicciopasticcio1 è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2012, 08:45   #12
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da VICIUS Guarda i messaggi
L'ordine degli operandi non importa ci pensa il db a scegliere l'ordine migliore in base agli indici che ha a disposizione.
Dipende dal DBMS. MySQL, ad esempio, ha forti problemi con le subquery, che non riesce a trasformare in join et similia o a sfruttare gli indici, e capita non di rado che una query semplice si trasformi in una table scan... ripetuta parecchie volte.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2012, 08:54   #13
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
Dipende dal DBMS. MySQL, ad esempio, ha forti problemi con le subquery, che non riesce a trasformare in join et similia o a sfruttare gli indici, e capita non di rado che una query semplice si trasformi in una table scan... ripetuta parecchie volte.
davero?
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2012, 09:16   #14
VICIUS
Senior Member
 
L'Avatar di VICIUS
 
Iscritto dal: Oct 2001
Messaggi: 11471
Quote:
Originariamente inviato da The_ouroboros Guarda i messaggi
davero?
Si per via di come costruisce le join internamente mysql ha sempre avuto problemi con quel genere di query. Diciamo che a volte cerca di aiutare la subquery spostando una o più condizioni dalla principale a quella annidata ma facendolo a volte fa casini.

Quella postata così a naso non dovrebbe avere problemi.
VICIUS è offline   Rispondi citando il messaggio o parte di esso
Old 05-12-2012, 09:43   #15
The_ouroboros
Senior Member
 
L'Avatar di The_ouroboros
 
Iscritto dal: May 2007
Città: Milano
Messaggi: 7103
Quote:
Originariamente inviato da VICIUS Guarda i messaggi
Si per via di come costruisce le join internamente mysql ha sempre avuto problemi con quel genere di query. Diciamo che a volte cerca di aiutare la subquery spostando una o più condizioni dalla principale a quella annidata ma facendolo a volte fa casini.

Quella postata così a naso non dovrebbe avere problemi.
ri ringrazio per le utili info
__________________
Apple Watch Ultra + iPhone 15 Pro Max + Rog Ally + Legion Go
The_ouroboros è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


ASUS ROG Swift OLED PG34WCDN recensione: il primo QD-OLED RGB da 360 Hz ASUS ROG Swift OLED PG34WCDN recensione: il prim...
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Secondo Elon Musk FSD è più...
Anche Cloudflare fissa il 2029 per la si...
Hacker sfruttano da mesi un bug segreto ...
ASUSTOR Lockerstor 24R Pro Gen2: 24 bay ...
Rigetti supera la soglia dei 100 qubit: ...
eFootball raggiunge il miliardo di downl...
Come provare OpenClaw facilmente grazie ...
Microsoft conferma: questo glitch dell'o...
Toyota bZ7: una berlina da oltre 5 metri...
Artemis II, le prime foto del lato nasco...
Sempre più pubblicità su YouTube: arriva...
Polestar fa +80% in Italia e tocca quota...
Il tuo Mac smette di connettersi a Inter...
La nuova alleanza Intel-Google ridefinis...
Energia troppo cara, regole da rivedere:...
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: 23:04.


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