Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza
OPPO Reno14 F 5G si propone come smartphone di fascia media con caratteristiche equilibrate. Il device monta processore Qualcomm Snapdragon 6 Gen 1, display AMOLED da 6,57 pollici a 120Hz, tripla fotocamera posteriore con sensore principale da 50MP e generosa batteria da 6000mAh con ricarica rapida a 45W. Si posiziona come alternativa accessibile nella gamma Reno14, proponendo un design curato e tutto quello che serve per un uso senza troppe preoccupazioni.
Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 06-07-2009, 18: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 06-07-2009, 23: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, 15: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, 11: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


Sottile, leggero e dall'autonomia WOW: OPPO Reno14 F conquista con stile e sostanza Sottile, leggero e dall'autonomia WOW: OPPO Reno...
Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Osservata esplosione di raggi gamma (GRB...
Sean Duffy (amministratore ad interim de...
Renault lancia la super promo: porte ape...
Il tuo portatile ASUS ROG non funziona c...
Zoom migliora il suo operatore virtuale ...
Traguardo Omoda & Jaecoo in Italia: ...
EHT mostra nuove immagini di come cambia...
Il gioiellino di Fastned: aperti in Belg...
La nuova mini workstation AI di MinisFor...
Formula 1 2026, nuove gare Sprint in cal...
MacBook Pro con display OLED e supporto ...
Poste Italiane: dati di milioni di utent...
Microsoft blocca RaccoonO365, rubate olt...
15 anni dopo Skate 3, il gioco torna sot...
Molte novità per MongoDB: version...
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:09.


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