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 09-05-2003, 18:45   #1
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Interrogazione abbastanza tosta in SQL . Chi mi aiuta ?

Non mi metto a scrivere tutto il testo del problema ma cercherò di essere chiaro .... in pratica questa è l'interrogazione che devo fare :


produrre l'elenco dei soci (con cognome,nome e telefono) che hanno un debito nella Bdt ( coloro che hanno usufruito di ore di prestazioni in numero superiore a quelle erogate ) ... ecco come ho cominciato

Codice:
SELECT soci.Cognome, soci.Nome, soci.Telefono
FROM soci, prestazioni
WHERE soci.Id=prestazioni.idricevitore
GROUP BY soci.Cognome, soci.Nome, soci.Telefono
HAVING Sum(prestazioni.Ore)> (SELECT sum(ore) ....ecco ora non son continuare .....

In pratica ogni socio eroga un certo numero di ore per ciascuna prestazione .... faccio la somma delle ore per ogni socio che le riceve infatti raggruppo la somma proprio per ciascun socio ..... il problema ora è che tale somma deve essere maggiore al numero di ore che quel socio ha erogato .... come diavolo faccio ? Per favore aiutatemi
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:04   #2
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Re: Interrogazione abbastanza tosta in SQL . Chi mi aiuta ?

Vediamo se ho capito...

SELECT A.Cognome, A.Nome, A.Telefono
FROM soci As A, prestazioni As B
WHERE A.Id=B.idricevitore
GROUP BY A.Cognome, A.Nome, A.Telefono
HAVING Sum(B.Ore)> (SELECT sum(ore) FROM Prestazione WHERE Id = A.Id);

L'Id che ho sottilineato deve essere il compo di Prestazioni che corrisponde all'Id del socio che esegue la prestazione...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:20   #3
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Si cionci avevo pensato anche io a questo ma quell'A.id non è sempre lo stesso ... Supponiamo di effettuare la somma delle ore e raggruppare per Mario Rossi 081/8865472 ; Ora mario rossi avrà un suo id .... questo id sarà diverso dalla persona successiva quindi quale di questo sarà utilizzato dal secondo select ?
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:26   #4
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Cmq al massimo dovrebbe essere così :

Codice:
SELECT A.Cognome, A.Nome, A.Telefono 
FROM soci As A, prestazioni As B 
WHERE A.Id=B.idricevitore 
GROUP BY A.Cognome, A.Nome, A.Telefono 
HAVING Sum(B.Ore)> (SELECT sum(ore) FROM Prestazione WHERE Id = Prestazioni.Id);
Non puoi specificare per l'ultimo select A.id perché non lo riconoscerebbe .... Ma resto ancora nel dubbio di prima ....
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:28   #5
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Se raggruppi anche per A.Id dovrebbe funzionare...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:29   #6
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Cmq ho provato e come avevo dubitato non funziona .... ma in fondo lo avevo immaginato .... ora non so se sono riuscito a farti capire il problema ma quell'A.id che io poi ho modificato in Prestazioni.Id come faccio a dirgli che è quello del primo nome di raggruppamento , poi del secondo e così via ? Capisci .... Ne ho fatte centinaia di interrogazioni complesse ma una così non mi era mai capitata
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:32   #7
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Appunto...avevo messo gli As apposta... Lo dovevi lasciare come A.Id
Lui si va a prendere il valore attuale di A.id da A della prima parte della query
Codice:
SELECT A.Cognome, A.Nome, A.Telefono 
FROM soci As A, prestazioni As B 
WHERE A.Id=B.idricevitore 
GROUP BY A.Id, A.Cognome, A.Nome, A.Telefono 
HAVING Sum(B.Ore)> (SELECT sum(ore) FROM Prestazioni WHERE Id = A.Id);
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:38   #8
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
No cionci ... ho copiato il codice così come lo hai scritto ma nulla da fare non funziona
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:38   #9
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Che ti dice ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:39   #10
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Scusa scusa ..... si ora funziona ..... ecco il codice :

Codice:
SELECT A.Cognome, A.Nome, A.Telefono
FROM soci AS A, prestazioni AS B
WHERE (((A.Id)=[B].[idricevitore]))
GROUP BY A.Cognome, A.Nome, A.Telefono, A.Id
HAVING (((Sum(B.Ore))>(SELECT sum(ore) FROM Prestazioni WHERE Iderogatore = A.Id)));
Sei come al solito un grande
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:42   #11
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originally posted by "leon84"

Scusa scusa ..... si ora funziona
Bene
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:44   #12
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Allora ora ho capito : hai usato quell'A invece di soci nel secondo select per fare in modo che l'id sia quello del primo .... ma cmq ho ancora un dubbio .... si funziona alla perfeziona ma quando viene eseguito quel codice non mi va prima ad eseguire il primo select e poi alla fine eliminare le righe che non soddisfano alla seconda consizione ? Se è così e quindi dopo che sono state scandite tutti gli id nel primo select come fa a ricordarsi quegli id per il secondo ? Ciò mi porta a pensare che ogni riga viene creata testando ogni istruzione senza eseguire il primo select e poi il secondo giusto ?
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:52   #13
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
No...

La prima cosa che fa è il prodotto fra le tabelle A e B...
Si fa una tabellona composta sia dagli attributi di A che dagli attributi di B in cui inserisci righe formate da tutte le combinazioni possibili fra le righe di A e quelle di B...

Di tutte le righe così ottenute si tiene solo quelle che soddisfano A.Id=B.idricevitore...

Si ordina le righe per i parametri con cui si raggruppa...

Comincia a scorrersi le righe... Su quelle che hanno gli stessi parametri A.Cognome, A.Nome, A.Telefono, A.Id va a valutare HAVING...quindi quando valuta la SELECT dentro HAVING sa già quale valore ha A.Id per quella serie di righe che ha A.Cognome, A.Nome, A.Telefono, A.Id in comune...

Se le condizioni di HAVING sono soddisfatte allora i valore di A.Cognome, A.Nome, A.Telefono entrano nella soluzione...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 19:55   #14
leon84
Senior Member
 
L'Avatar di leon84
 
Iscritto dal: Jul 2002
Città: Napoli
Messaggi: 1964
Ah capisco .... quindi ciascuna riga viene generata in modo sequenziale .... io sai cosa credevo ? Credevo che effettuasse la congiunzione delle due tabelle , raggruppasse per cognome,nome,telefono tutte le righe ..... poi in una seconda fase elimina quelle righe che non soddisfano alla condizione dell'Having ... Pensando in questo modo è chiaro che non riuscivo a capirne il perché della tua scrittura .... Cmq come al solito ti ringranzio tantissimo .....
leon84 è offline   Rispondi citando il messaggio o parte di esso
Old 09-05-2003, 20:00   #15
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
E' un piacere
cionci è 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 ...
Riot Games alza lasticella dell'anti-che...
Netflix dice addio a 111 titoli original...
Samsung prepara un foldable più l...
Nintendo Switch 2: in arrivo cartucce pi...
Evento storico: la prima squadra di robo...
Fallito il lancio del razzo spaziale nip...
Truffa RAM: moduli DDR4 spacciati per DD...
Bureau 1440 mostra un'immagine di un sat...
Revocati i premi a Clair Obscur: Expedit...
Robotaxi Tracker, un 19enne ha scoperto ...
Il razzo spaziale riutilizzabile cinese ...
Apple Watch SE 3 in offerta su Amazon: i...
Eldegarde: l'action RPG firmato dagli ex...
Bici elettrica da città in offerta: F.ll...
Va al minimo storico DJI Osmo Action 4, ...
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: 14:42.


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