Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria
vivo X300 Pro rappresenta un'evoluzione misurata della serie fotografica del produttore cinese, con un sistema di fotocamere migliorato, chipset Dimensity 9500 di ultima generazione e l'arrivo dell'interfaccia OriginOS 6 anche sui modelli internazionali. La scelta di limitare la batteria a 5.440mAh nel mercato europeo, rispetto ai 6.510mAh disponibili altrove, fa storcere un po' il naso
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo
Lenovo Legion Go 2 è la nuova handheld PC gaming con processore AMD Ryzen Z2 Extreme (8 core Zen 5/5c, GPU RDNA 3.5 16 CU) e schermo OLED 8,8" 1920x1200 144Hz. È dotata anche di controller rimovibili TrueStrike con joystick Hall effect e una batteria da 74Wh. Rispetto al dispositivo che l'ha preceduta, migliora ergonomia e prestazioni a basse risoluzioni, ma pesa 920g e costa 1.299€ nella configurazione con 32GB RAM/1TB SSD e Z2 Extreme
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti
A re:Invent 2025, AWS mostra un’evoluzione profonda della propria strategia: l’IA diventa una piattaforma di servizi sempre più pronta all’uso, con agenti e modelli preconfigurati che accelerano lo sviluppo, mentre il cloud resta la base imprescindibile per governare dati, complessità e lock-in in uno scenario sempre più orientato all’hybrid cloud
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


Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'' per spingere gli handheld gaming PC al massimo Lenovo Legion Go 2: Ryzen Z2 Extreme e OLED 8,8'...
AWS re:Invent 2025: inizia l'era dell'AI-as-a-Service con al centro gli agenti AWS re:Invent 2025: inizia l'era dell'AI-as-a-Se...
Cos'è la bolla dell'IA e perché se ne parla Cos'è la bolla dell'IA e perché se...
BOOX Palma 2 Pro in prova: l'e-reader diventa a colori, e davvero tascabile BOOX Palma 2 Pro in prova: l'e-reader diventa a ...
Il nucleo della cometa interstellare 3I/...
La Russia potrebbe sviluppare un'arma pe...
Manda la RAM Corsair in assistenza, rice...
ASUS ROG G1000 con 'AniMe Holo': saranno...
Un test di longevità ha messo alla prova...
Incat inizia i test dell'incredibile tra...
LG Sound Suite: al CES il sistema audio ...
Avengers Doomsday, il primo trailer &egr...
La crisi delle memorie non farà sconti a...
Il trailer più atteso dell'anno &...
I gamer vogliono i monitor OLED: sopratt...
Samsung alza l’asticella dei televisori ...
Energie rinnovabili 2025: quasi 42% del ...
Le auto elettriche volano in tutta Europ...
Nuovo look per la finestra Esegui su Win...
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: 07:15.


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