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.