Search code examples
sqlnormalize

What would be a better way to create my database of food?


I have taken on the project of creating a relation database which will contains all the basic ingredients we use in modern cooking. As you could imagine, there are going to be thousands of items. I do not have much sql experience so I am having trouble arriving at a seemingly efficient way of storing the ingredients. If you go here http://en.wikipedia.org/wiki/Outline_of_food_preparation#General_ingredients you can see the list I am currently trying to put into my database.

My database current has a table for every main and sub category of food ex. a table for cereals and a different table for wheat. At first it seemed okay to do this, but then i realized that there are going to be dozens more sub categories. For each item in that wiki list there are more tables and more tables that I must create. I feel like this plethora of tables will make my project very inefficient. Is there a better way to create my database? Or am I on the right track? Here is an example of the columns in my tables:

    id INT(11),name VARCHAR(45),parent INT(11),img VARCHAR(45),desc VARCHAR(45)

parent INT(11) will be a foreign key to whatever the parent table is, so I figured they will all connect this way. Any advice is appreciated! ~THANKS


Solution

  • I would first not recommend storing all these in separate tables -- it'll drive you crazy :-)

    Instead however, I think you have 2 options.

    Option 1 (Adjacency List Model) -- Consider using a single Foods table, with FoodId, FoodName, ParentFoodId, AnyOtherAttributes you wish to store. This is easiest to store the data, but can be a little more troublesome to return your results as you'll need to join on the same table multiple times to return levels.

    Option 2 (Nested Set Model) -- This option still would have the single Foods table, but instead of having a ParentFoodId, you'ld have 2 columns, left_index and right_index. This is perhaps a little more complicated to understand at first, but can be easier to query if you have several unknown nested parent-to-child relationships.

    Take a look at this article for some further explanations:

    http://mikehillyer.com/articles/managing-hierarchical-data-in-mysql/

    Good luck.