Databasemodel
Du har grundlæggende brug for en many-to-many
forholdet mellem forfattere og publikationer, da én forfatter kan skrive mange publikationer, og én publikation kan være skrevet af mere end én forfatter.
Dette kræver, at du har 3 borde.
- Forfatter – generel information om hver forfatter (uden publications_id)
- Publikation – generel information om hver udgivelse (uden forfatter_id)
- AuthorPulication - kolonner
author_id
ogpublication_id
der er referencer til tabellerAuthor
ogPublication
.
På denne måde binder du ikke en bestemt forfatter til en publikation, men du kan have flere af dem, og det samme omvendt.
Yderligere bemærkninger
Hvis du gerne vil skelne forfatternes rolle i en bestemt publikation, kan du også tilføje en kolonne som id_role
det ville være en henvisning til en ordbogstabel, der angiver alle mulige roller for en forfatter. På denne måde kan du være forskellig mellem førende forfattere, medforfattere osv. På denne måde kan du også gemme oplysninger om personer, der håndterer oversættelse af bogen, men måske skulle du så ændre navnet på Author
til noget mindre specifikt.
Udseenderækkefølge
Du kan sikre en korrekt rækkefølge af dine forfattere ved at tilføje en kolonne i AuthorPublication
som du vil øge separat for hver Publication
. På denne måde ville du være i stand til at bevare bestillingen efter behov.