Torna indietro   Hardware Upgrade Forum > Software > Programmazione

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 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
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
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


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...
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...
Ducati presenta la moto elettrica con ba...
Pikachu Illustrator, la carta Poké...
Mini PC da urlo: prestazioni da desktop ...
Windows 10, scatta il conto alla rovesci...
Errore 1603: AMD spiega come risolvere i...
Semiconduttori, tensioni in aumento: la ...
vivo X200 FE: la potenza di un flagship ...
Amazon fa impazzire i prezzi: ecco i 5 s...
iOS 26 arriva oggi: 8 motivi per aggiorn...
VMSCAPE, nuova variante Spectre: vulnera...
Meta Quest 3 da 512 GB scende ancora: or...
Xiaomi lancia un nuovo e-reader con Andr...
iPhone 16e a meno di 600€ su Amazon: l'a...
NVIDIA arruola Colin King: Intel perde u...
GeForce RTX 6090: Rubin CPX potrebbe ess...
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: 10:02.


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