I am developing web application where I have to implement ‘Likes’ system as facebook has. Application will have a few categories of products that customer can ‘like’. So I have started to create database, but I stuck on one obstacle. As I understand there are two ways of doing this:
First. Create one database table with fields of “id, user_id, item_category, item_id”. When user click ‘like’ button information will be saved in this table with various categories of products (item_category).
Second. Create several tables for certain categories of item. For instance, “tbl_item_category_1, tbl_item_category_2, tbl_item_category_3” with fields of “user_id, item_id”.
Would be great to get more insight about best practices of this kind database structures. Which works faster? and more logical/practical? I will use only several categories of items.
I would go with the first version with a table structure similar to this:
Here is a SQL Fiddle with demo of table structure with two sample queries to give the Total Likes by user and Total Likes by category
The second one – creating multiple tables is a terrible idea. If you have 50-100 categories trying to query those tables would be horrible. It would become completely unmanageable.
If you have multiple tables trying to get a the total likes would be:
Use one table, no question.