Torna indietro   Hardware Upgrade Forum > Software > Programmazione

La rivoluzione dei dati in tempo reale è in arrivo. Un assaggio a Confluent Current 2025
La rivoluzione dei dati in tempo reale è in arrivo. Un assaggio a Confluent Current 2025
Siamo andati a Londra per partecipare a Current 2025, la conferenza annuale di Confluent. Il tema al centro dell'evento era l'elaborazione dei dati in tempo reale resa possibile da Apache Kafka, una piattaforma open source pensata proprio per questo. Si è parlato di come stia cambiando la gestione dei dati in tempo reale, del perché sia importante e di quali siano le prospettive per il futuro
SAP Sapphire 2025: con Joule l'intelligenza artificiale guida app, dati e decisioni
SAP Sapphire 2025: con Joule l'intelligenza artificiale guida app, dati e decisioni
A Madrid SAP rilancia sulla visione di un ecosistema integrato dove app, dati e AI generano un circolo virtuoso capace di affrontare l’incertezza globale. Joule diventa l’interfaccia universale del business, anche oltre il perimetro SAP
Dalle radio a transistor ai Micro LED: il viaggio di Hisense da Qingdao al mondo intero
Dalle radio a transistor ai Micro LED: il viaggio di Hisense da Qingdao al mondo intero
Una delle realtà a maggiore crescita nel mondo dell'elettronica di consumo, Hisense Group, affonda le sue radici nella storica città portuale di Qingdao, famosa per la sua birra. Ed è proprio qui il centro nevralgico dell'espansione mondiale dell'azienda, che sta investendo massicciamente in infrastrutture e ricerca per consolidare ulteriormente la propria leadership tecnologica.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-01-2009, 11:03   #1
Doriän
Member
 
L'Avatar di Doriän
 
Iscritto dal: Nov 2006
Messaggi: 71
[Basi di Dati] Esercizi d'esame!

Mmh, ho appena visto che c'è un therad molto simile al mio in prima pagina, però non vorrei hijackarlo chiedendo li, qualche moderatore potrebbe dirmi se faccio bene ad aprirne un altro ?!
Comunque, sto preparando l'esame di BDA, e ogni tanto mi impantano in qualche query. Ho per esempio queste relazioni

Codice:
SQUADRE(IdSq, Nome, Città)
PARTITE(IdPartita, Data, Campionato, IdSqCasa, IdSqOspite, GolSqCasa, GolSqOspite)
sulle quali devo esprimere questa interrogazione:
Quote:
Selezionare il nome e il numero di gol segnati in casa nell’anno 1980
dalle squadre di Roma che, nell’anno 1980 in casa, hanno subito meno di 20 gol, ne hanno fatti più di 40, e hanno vinto almeno 13 partite.
Io ho buttato giù questa cosa:

Codice:
SELECT nome, sum(GolSqCasa)
FROM Squadre S join Partite P on S.IdSq = P.IdSqCasa
WHERE data like '%1980"
GROPU BY IdSqCasa
HAVING      sum(GolSqOspite) < 20
            and sum(GolSqCasa) > 40
Secondo me, questa interrogazione joina le due tabelle, mi seleziona solo i record per i quali la data finisce con 1980 e dopo effettua un raggruppamento per IdSqCasa per tutti i record che rispettano quelle condizioni. Anche posto che sia corretto, e non mi pare lo sia, come trovo quante partite hanno ?
Doriän è offline   Rispondi citando il messaggio o parte di esso
Old 16-01-2009, 11:25   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3691
Quote:
Originariamente inviato da Doriän Guarda i messaggi
Mmh, ho appena visto che c'è un therad molto simile al mio in prima pagina, però non vorrei hijackarlo chiedendo li, qualche moderatore potrebbe dirmi se faccio bene ad aprirne un altro ?!
Comunque, sto preparando l'esame di BDA, e ogni tanto mi impantano in qualche query. Ho per esempio queste relazioni

Codice:
SQUADRE(IdSq, Nome, Città)
PARTITE(IdPartita, Data, Campionato, IdSqCasa, IdSqOspite, GolSqCasa, GolSqOspite)
sulle quali devo esprimere questa interrogazione:


Io ho buttato giù questa cosa:

Codice:
SELECT nome, sum(GolSqCasa)
FROM Squadre S join Partite P on S.IdSq = P.IdSqCasa
WHERE data like '%1980"
GROPU BY IdSqCasa
HAVING      sum(GolSqOspite) < 20
            and sum(GolSqCasa) > 40
Secondo me, questa interrogazione joina le due tabelle, mi seleziona solo i record per i quali la data finisce con 1980 e dopo effettua un raggruppamento per IdSqCasa per tutti i record che rispettano quelle condizioni. Anche posto che sia corretto, e non mi pare lo sia, come trovo quante partite hanno ?
Finora dovrebbe essere tutto giusto.
Il numero di partite e' il numero di record della tabella Partite
__________________
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
Old 16-01-2009, 12:03   #3
Doriän
Member
 
L'Avatar di Doriän
 
Iscritto dal: Nov 2006
Messaggi: 71
Mmh, ottimo spunto di riflessione! Vediamo: a me interessano i record (ossia le righe) che rispettino quei due parametri riguardanti i gol, ma allo stesso tempo che rispettino anche il vincolo sul numero di partite, mettiamola così. Il numero di record lo trovo con count(*), giusto?

Codice:
SELECT nome, sum(GolSqCasa)
FROM Squadre S join Partite P on S.IdSq = P.IdSqCasa
WHERE data like '%1980"
GROUP BY IdSqCasa
HAVING      sum(GolSqOspite) < 20
            and sum(GolSqCasa) > 40
            and count(*) >= 13
Questa interrogazione mi seleziona tutte le partite, raggruppandole per squadre, dove il totale delle partite sia almeno 13, il totale di gol segnati siano quelli, e mi restituisce nome della squadra e totale di gol segnati. È corretto?!
Doriän è offline   Rispondi citando il messaggio o parte di esso
Old 16-01-2009, 12:10   #4
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3691
Giusto!
__________________
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
Old 16-01-2009, 14:38   #5
Doriän
Member
 
L'Avatar di Doriän
 
Iscritto dal: Nov 2006
Messaggi: 71
ottimo! grazie gugo, ora procedo e se mi incastro vengo a chiedere
Doriän è offline   Rispondi citando il messaggio o parte di esso
Old 16-01-2009, 15:05   #6
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3691
Quote:
Originariamente inviato da Doriän Guarda i messaggi
ottimo! grazie gugo, ora procedo e se mi incastro vengo a chiedere
Purtroppo c'e' un errore che vedo ora.
Da SQL Standard, a fronte di una GROUP BY, puoi selezionare solo le colonne per cui hai fatto GROUP BY (piu' una serie di altre possibilita' che trovi qui
http://www.hwupgrade.it/forum/showthread.php?t=1906542)
al che non puoi selezionare
nome
se raggruppi per IdSqCasa

Fatto salvo che i nomi delle squadre siano tutti diversi (che e' normale, ma che dovrebbe essere rinforzato da un Constraint di univocita' sulla colonna), puoi raggruppare direttamente per nome.

PS: MySql, che non e' standard, permette una scrittura come quella da te esposta, ma motori piu' seri l'avrebbero rifiutata.
__________________
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.

Ultima modifica di gugoXX : 16-01-2009 alle 15:08.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


La rivoluzione dei dati in tempo reale è in arrivo. Un assaggio a Confluent Current 2025 La rivoluzione dei dati in tempo reale è ...
SAP Sapphire 2025: con Joule l'intelligenza artificiale guida app, dati e decisioni SAP Sapphire 2025: con Joule l'intelligenza arti...
Dalle radio a transistor ai Micro LED: il viaggio di Hisense da Qingdao al mondo intero Dalle radio a transistor ai Micro LED: il viaggi...
Meglio un MacBook o un PC portatile con Windows, oggi? Scenari, dubbi e qualche certezza Meglio un MacBook o un PC portatile con Windows,...
realme GT7: un "flaghsip killer" concreto! La recensione realme GT7: un "flaghsip killer" concr...
WhatsApp sta per introdurre gli username...
Successo per il primo test della PEC eur...
Cosa cambia con la partnership fra Pure ...
Sony abbandona la produzione interna deg...
Il futuro degli aerei elettrici passa pe...
Sentenza blocca i dazi di Trump: "I...
Xiaomi SU7 è super popolare nei m...
AMAZFIT Active 2 a 94€ e tutti gli altri...
Smartphone con super batteria: Realme pr...
L'IA supererà Bitcoin: consumi en...
E-tattoo: arriva il tatuaggio elettronic...
GreenMindAI Hackathon Catania: annunciat...
DeepSeek R1 si aggiorna: l'IA cinese ade...
Torna in offerta il portatile Lenovo con...
Windows 11: problemi di avvio dopo l'upd...
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: 13:50.


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