Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 22-09-2010, 17:43   #1
Zoddicus
Member
 
L'Avatar di Zoddicus
 
Iscritto dal: Dec 2005
Messaggi: 36
[JAVA] relazioni tra Entity con JPA

Salve, vorrei esporvi un problema che mi cruccia da qualche giorno, sto realizzando per un progetto d’esame un sito con JSP e JPA, il sito simula un negozio online per la vendita di cd. I miei Entity sono : Utente, Artista, CasaDiscografica, Acquisto, CD; da relazioni tra CD e Artista viene creata una tabella che associa queste due tabelle, “composizione”, che associa un Artista ai CD di cui è autore e i CD agli Artisti che lo hanno composto, fin qui tutto ok,dopo vari test però mi sono accorto, con disappunto, che per come viene creato il database è impossibile realizzare un Acquisto in cui compare più volte lo stesso cd, questo perché CD mappa gli acquisti in cui è coinvolto con una Collection<Acquisto > e viceversa Acquisto mappa i CD che vengono acquistati con una Collection<CD>, cosicchè viene creata una JoinTable come “composizione” che ha 2 elementi, uno è la chiave di Acquisto e l’altra la chiave di CD, il problema è che in questo modo se avessi l’ipotetico Acquisto che contiene come cd acquistati 2 CD uguali(oppure 3 e così via) dovrei allora avere due righe della tabella associativa esattamente uguali. Quindi nell’entity CD ho:
@ManyToMany(fetch = FetchType.EAGER)
private Collection<Acquisto> acquistoCollection;
mentre in Acquisto ho:
@ManyToMany(mappedBy = "acquistoCollection", fetch = FetchType.EAGER)
private Collection<CD> cd;



essendo un problema che nella creazione di un sistema come quello che vorrei realizzare esiste sempre sono sicuro che ci sia una soluzione….ma non riesco a trovarla! Grazie per le risposte
Zoddicus è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2010, 09:22   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Non mi intendo di JPA e compagnia bella, ma non è possibile, che so, associare ad una entità "CD" una entità "Quantità" (durante un Acquisto)?
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 23-09-2010, 15:26   #3
british
Member
 
L'Avatar di british
 
Iscritto dal: Sep 2008
Città: Milano
Messaggi: 126
Non è un problema di JPA ma di progettazione del modello concettuale.
Comunque, il suggerimento di banryu79 è corretto: aggiungi alla relazione CDAcquisto un identificativo "quantita".

ciao!

british
british è offline   Rispondi citando il messaggio o parte di esso
Old 25-09-2010, 18:14   #4
Zoddicus
Member
 
L'Avatar di Zoddicus
 
Iscritto dal: Dec 2005
Messaggi: 36
grazie per la risposta , purtroppo ho avuto problemi di connessione in questi giorni e leggo solo ora, quindi nel frattempo la soluzione da me trovata è un po' diversa, ma nella sostanza quella che hai consigliato tu(perchè hai assolutamente ragione quando dici che il mio modello concettuale era sbagliato! ) In pratica la mia scelta è meno efficiente, perchè non ho messo riferimenti espiciti alla quantità, ho creato un nuovo entity, Acquisto_CD( in realtà il nome è Acquisto_CD_Qta per il motivo che spiego sotto XD ) , in cui associo ad un Acquisto un CD(uno solo), il problema che avevo così si è risolto perchè questa nuova tabella non ha gli id di Acquisto e CD come chiavi esterne,bensì una tutta sua, così ora se avessi ad esempio Acquisto1 che contiene 3 esemplari di CD1 avrei 3 record della tabella Acquisto_CD simili a questi:
id Acquisto(id) CD(id)
record1 : 1 1 1
record2: 2 1 1
record3: 3 1 1

il riferimento alla quantità mi era venuto in mente(tanto è vero che l'Entity nuovo si chiama Aquisto_CD_Qta e il nome è rimasto lol ) però l'ho tralasciata perchè mi era più facile, se mettessi anche la quantità dovrei prima di ogni inserimento verificare se esiste già un record con quell' Acquisto e quel Cd e aggiornargli la quantità , anche perchè spero sia un'operazione rara acquistare molte copie dello stesso Cd in uno stesso Acquisto. Pensate possa andar bene lo stesso?
Zoddicus è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2010, 18:12   #5
MEMon
Senior Member
 
Iscritto dal: Dec 2002
Messaggi: 3359
Quote:
Originariamente inviato da Zoddicus Guarda i messaggi
grazie per la risposta , purtroppo ho avuto problemi di connessione in questi giorni e leggo solo ora, quindi nel frattempo la soluzione da me trovata è un po' diversa, ma nella sostanza quella che hai consigliato tu(perchè hai assolutamente ragione quando dici che il mio modello concettuale era sbagliato! ) In pratica la mia scelta è meno efficiente, perchè non ho messo riferimenti espiciti alla quantità, ho creato un nuovo entity, Acquisto_CD( in realtà il nome è Acquisto_CD_Qta per il motivo che spiego sotto XD ) , in cui associo ad un Acquisto un CD(uno solo), il problema che avevo così si è risolto perchè questa nuova tabella non ha gli id di Acquisto e CD come chiavi esterne,bensì una tutta sua, così ora se avessi ad esempio Acquisto1 che contiene 3 esemplari di CD1 avrei 3 record della tabella Acquisto_CD simili a questi:
id Acquisto(id) CD(id)
record1 : 1 1 1
record2: 2 1 1
record3: 3 1 1

il riferimento alla quantità mi era venuto in mente(tanto è vero che l'Entity nuovo si chiama Aquisto_CD_Qta e il nome è rimasto lol ) però l'ho tralasciata perchè mi era più facile, se mettessi anche la quantità dovrei prima di ogni inserimento verificare se esiste già un record con quell' Acquisto e quel Cd e aggiornargli la quantità , anche perchè spero sia un'operazione rara acquistare molte copie dello stesso Cd in uno stesso Acquisto. Pensate possa andar bene lo stesso?
Il problema che avevi prima rimane, cioè hai sempre record multipli che si riferiscono al medesimo acquisto del medesimo oggetto.

La soluzione è quella che ti han già proposto, basta mettere una quantità all'acquisto del determinato oggetto.
Il problema che esponi è un problema di interfaccia, il software dovrà avere una gui tale che al momento della creazione di un acquisto sai già cosa e quanto comprare, non che ogni volta riapri l'acquisto e lo modifichi...
MEMon è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Ford: l'elettrico genera una perdita di ...
Ayaneo Next 2: la console portatile Wind...
Il WiFi può vederti senza telecam...
Linux sotto assedio: SSHStalker riporta ...
Stellantis: dopo il crollo di venerd&igr...
Combat Liquid 360 HUD: raffreddamento AI...
Tornano le EVO Sessions della Formula E:...
Moltbook, il social network per AI: i po...
Cina: eseguito il test della navicella M...
Mistral, il rivale europeo di OpenAI, in...
Libri piratati, allarme rosso: 722 milio...
Ayaneo svela quasi tutte le specifiche d...
Sony chiude definitivamente con i regist...
Renault Twingo E-Tech Electric sotto i 2...
Auto elettriche, il freddo non fa pi&ugr...
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:43.


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