Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Destiny Rising: quando un gioco mobile supera il gioco originale
Destiny Rising: quando un gioco mobile supera il gioco originale
Tra il declino di Destiny 2 e la crisi di Bungie, il nuovo titolo mobile sviluppato da NetEase sorprende per profondità e varietà. Rising offre ciò che il live service di Bungie non riesce più a garantire, riportando i giocatori in un universo coerente. Un confronto che mette in luce i limiti tecnici e strategici dello studio di Bellevue
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
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.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 03-07-2009, 16:42   #1
sboby
Member
 
Iscritto dal: Jul 2007
Messaggi: 40
[mysql] Dubbio su derivazione da modello concettuale

Devo implementare un sistema di commenti su un sito di recensioni musicali.
I commenti possono essere postati sulla bacheca di un artista, di un utente, di un album o possono riferirsi a una recensione.


N [commento] N ---- <scrive ---- 1 [utente]
|
|------------- 1 [utente]
|
|------------- 1 [recensione]
|
|------------- 1 [album]
|
|------------- 1 [artista]


Mi trovo dunque di fronte a un'entità(commento) in associazione molti a uno con altre 3 entità, ed è chiaro che se il commento è riferito a una recensione non lo è per un artista.
Qual'è il miglior modo di derivare questo schema?

-Potrei fare un'unica tabella "commenti", ed altre 4 per le citate associazioni: idutente, idrecensione, id album, idautore. In questo caso per ogni record di "commenti" resterebbero 3 campi vuoti.

-Potrei fare 4 tabelle: commenti_ad_utenti, commenti_recensioni, commenti_artisti, commenti_album.
esempio: commenti_recensioni{id, idautore, id recensione, testo, data}

La soluzione che ho pensato io è fare una tabella "commenti" con una sola chiave esterna per l'autore, seguita da altre 4 tabelle: commenti_artisti, commenti_rece, commenti_album e commenti_ad_utente che associno il commento rispettivamente all'artista, alla recensione...
esempio:
commenti{id, idautore, data, testo}
commenti_rece{idcommento, idrecensione}
commenti_album{idcommento, idalbum}

Una birra a chi risponde.
__________________
Sboby's pc
Cpu: Intel Core2 Quad Q6600 | MoBo: Asus P5E | Ram: OCZ DDR2 PC2-8500 Platinum SLI-Ready | Vga: Twintech 9800Gtx 512Mb | Hdd: 2x Western Digital 250 Gb SataII 7200rpm | Case: Cooler Master Cosmos 1000 + Scythe S-FLEX 120mm fan 1600 rpm | Ali: Enermax 625w EPR625AWT PRO82+
sboby è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2009, 16:54   #2
anonimizzato
 
Messaggi: n/a
Quote:
Originariamente inviato da sboby Guarda i messaggi
Una birra a chi risponde.
Ma basta rispondere a caso o vuoi una cosa sensata?

Comunque:
La soluzione dell'unica tabella con 4 chiavi esterne di cui solo una di volta in volta popolata non mi piace.

Meglio la soluzione multitabellare per ciascucun tipo di commento oppure più semplicemente un'unica tabella per i commenti, l'id dell'autore e poi un campo che definisca il "tipo" di commento. (In Ruby on Rails sarebbe un'associazione polimorfica)

In pratica
id_commento,id_autore,id_tipo

dove id_tipo può essere una chiave esterna della tabella "commento_tipi"
id,tipo (recension,album,artista ecc.)

Ma anche l'ultima soluzione che hai indicato con le tabelle di "specializzazione" può andare bene.
  Rispondi citando il messaggio o parte di esso
Old 03-07-2009, 17:16   #3
sboby
Member
 
Iscritto dal: Jul 2007
Messaggi: 40
Quote:
Ma basta rispondere a caso o vuoi una cosa sensata?
Lol, la tua risposta è sensata, birra per te

La tua soluzione alternativa è ottima, però se volessi applicare delle regole referenziali?

Il problema è che vorrei che venisse qualcuno molto esperto e dicesse: "QUELLA è la migliore perchè..." senza lasciare spazio alle altre soluzioni

Grazie della risposta
__________________
Sboby's pc
Cpu: Intel Core2 Quad Q6600 | MoBo: Asus P5E | Ram: OCZ DDR2 PC2-8500 Platinum SLI-Ready | Vga: Twintech 9800Gtx 512Mb | Hdd: 2x Western Digital 250 Gb SataII 7200rpm | Case: Cooler Master Cosmos 1000 + Scythe S-FLEX 120mm fan 1600 rpm | Ali: Enermax 625w EPR625AWT PRO82+
sboby è offline   Rispondi citando il messaggio o parte di esso
Old 03-07-2009, 17:46   #4
anonimizzato
 
Messaggi: n/a
Da un punto di vista di mera normalizzazione credo che l'ultima ipotesi che avevi indicato sia la migliore.
  Rispondi citando il messaggio o parte di esso
 Rispondi


Destiny Rising: quando un gioco mobile supera il gioco originale Destiny Rising: quando un gioco mobile supera il...
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
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ù...
iPhone 16 128GB bianco a 679€, 16e a 599...
Rigonfiamenti improvvisi della batteria:...
RoboBall è un robot a forma di pa...
Nothing guarda al futuro: nuovi finanzia...
Realme punta sulla fascia bassa: arriva ...
Interlune creerà un centro di ric...
Stop Killing Games: 97% delle firme conv...
La GTX 2080 Ti mai arrivata sul mercato,...
Hoolow Knight: Silksong, il gioco che a ...
Duolingo crolla in Borsa: la minaccia ar...
Battlefield 6: i giocatori console potra...
Citroen Racing, la marca ritorna alle co...
Windows 10 ESU: come partecipare al prog...
ASUS Vivobook 16X a meno di 470€ su Amaz...
Con Agent Payments Protocol di Google gl...
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:12.


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