Reputation: 4371
I wonder,
at many websites there is the option to like/dislike a post.
even here of course, at stackoverflow.
so, technically it's a big likes table?
user_id post_id
user_id - who voted
post_id - which post is it
is that all about?
a big likes table?
isn't there something more efficient/sophisticated?
Upvotes: 29
Views: 18304
Reputation: 286
I think I can understand your concern. Having to issue a COUNT() everytime the page needs to be presented.
You certainly have to have this basic table, which will be the basis for a COUNT(), but you don't really need to COUNT() it for every access.
Create a totalling table and update it either when the page receives a like or dislike, using a trigger, or call a stored procedure to update it from time to time.
I would say each method is more indicated for different site personalities, ie, more readings or more writings, but you already know that when it comes to likes or dislikes nothing is previsible.
Upvotes: 11
Reputation: 7991
At it's most basic level, yes, that's all it is.
But then it starts to expand, trying to answer questions like:
Then you start to want to answer more in depth questions about friends and the community.
Upvotes: 24