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 06-07-2009, 19:49   #1
Jwalker
Member
 
L'Avatar di Jwalker
 
Iscritto dal: May 2009
Messaggi: 44
[SQL] Chiarimento su due query

Salve. Ho un db così fatto

AUTO(TARGA,MARCA,MODELLO)
CLIENTE (CF,NOME,CITTA)
ACQUISTO (TARGA,CF,DATA,PREZZO,KM)
FK: TARGA REFERENCES AUTO
CF REFERENCES CLIENTE

e queste due query

Selezionare i CLIENTI che hanno acquistato tutte le auto (precedentemente o successivamente)
acquistate dal CLIENTE con cf ‘ABC’;

Codice:
SELECT *
FROM CLIENTE CL
WHERE NOT EXISTS ( SELECT *
                                 FROM ACQUISTO T1
                                WHERE T1.CF = ’ABC’
                                 AND NOT EXISTS (SELECT *
                                                               FROM ACQUISTO T2
                                                                WHERE CL.CF = T2.CF
                                                                 AND T1.TARGA = T2.TARGA))
Selezionare per ogni cf i prezzi delle due AUTO acquistate con minor numero di km.

Codice:
 SELECT T.CF, T.PREZZO
  FROM ACQUISTO T
  WHERE 2 >= (   SELECT COUNT(*)
                           FROM ACQUISTO T1
                           WHERE T.CF = T1.CF
                           AND T1.KM <= T.KM)
ma non riesco proprio a capirle.... C'è nessuno così gentile da aiutarmi??

Ciao e grazie
Jwalker è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2009, 00:16   #2
RaouL_BennetH
Senior Member
 
L'Avatar di RaouL_BennetH
 
Iscritto dal: Sep 2004
Messaggi: 3967
Ciao

Non ho ben capito se queste query le devi analizzare perchè già esistenti oppure sono quelle che hai provato a fare tu per ottenere i risultati richiesti.


Le mie perplessità sono queste:

Per la prima query, personalmente avrei utilizzato una forma di confronto del tipo 'diverso_da' piuttosto che 'dove_non_esiste'. Se ho compreso bene la prima query, significa semplicemente:

Seleziona tutti i clienti dove 'ABC' non esiste o meglio, seleziona tutti i clienti che non corrispondono ad 'ABC'. Non capisco però cosa voglia significare un confronto anche sulla targa (forse è un parametro che passi alla query? ) ma, soprattutto, non capisco come si possa fare un confronto tra eventi successi PRIMA o DOPO un evento se non si considera anche un intervallo di date, per es.:

Codice:
....blabla WHERE ACQUISTO.DATA BETWEEN unaData and unaAltraData

La seconda poi mi fa sorgere spontanea la domanda:

perchè non utilizzare semplicemente un MIN(ACQUISTO.KM) ?
__________________
Dai wafer di silicio nasce: LoHacker... il primo biscotto Geek
RaouL_BennetH è offline   Rispondi citando il messaggio o parte di esso
Old 07-07-2009, 16:03   #3
Jwalker
Member
 
L'Avatar di Jwalker
 
Iscritto dal: May 2009
Messaggi: 44
quelle query sono soluzioni del prof, sono state date così, per buone,ed effettivamente anche se sembrano assurde funzionano... quello che volevo io è capirle.... cioè perchè sono state fatte così???
ad esempio, nella seconda che significa ".... 2 >= ( SELECT COUNT(*) .... "

Jwalker è offline   Rispondi citando il messaggio o parte di esso
Old 08-07-2009, 12:21   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
Bisogna cambiare un po' le frasi di richiesta in italiano per farle collimare con SQL

1. Enunciare ogni cliente tale per cui non esista nemmeno un'auto acquistata da ABC che non sia stata acquistata anche da tale cliente

2. Enunciare ciascun acquisto T di ogni cliente, tali per cui il numero di acquisti di tale cliente aventi kilometri inferiori a T sia minore o uguale a 2

Invece che
WHERE 2>= (SELECT COUNT(*) ....)
vedila come
WHERE (SELECT COUNT(*) ...) <=2
che e' piu' umanamente leggibile.


Per inciso, l'abilita' di trasformare le frasi in italiano in altre frasi in italiano pero' direttamente componibili in SQL e' una delle abilita' richieste per i modellatori e manutentori di Database.
__________________
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: 19:46.


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