I’m new to database design so please bear with me. I’m using PHP and MySQL.
I have a ‘movies’ table that contains some details about a movie. This includes genres, which have an (if I understand correctly) many to many relationship with movies, implying a single movie can belong to different genres and a single genre can belong to different movies.
From what I gather about database design, storing this kind of relationship in one table is not a good idea as it will either violate First Normal form or Second Normal form rules.
How would I design my tables to avoid this; would I have to create a table for each genre separately or… ?
This leads my to my next question: separate tables need to have foreign keys to identify which information belongs to what row. In theory, if I had a unique key identifying each movie which I would then like to use to identify a director in a separate table, how would I create this relationship in MySQL?
Thank you for your time – if I’ve made anything unclear please let me know and I will try my best to clarify.
That’s right.
Right. You’re looking for something loosely along these lines.
For directors, assuming there is only one director per movie, you can use this instead of the movies table above