Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6956517
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 27, 20262026-05-27T14:52:48+00:00 2026-05-27T14:52:48+00:00

This is a simplified version of the database design I have so far, for

  • 0

This is a simplified version of the database design I have so far, for a ‘Stack Overflow’ style voting system.

The question is: if the user has a score for the total number of votes they got for a response, should that score be worked out ‘on the fly’ or should there be a field in the users table referring to their score. Also if the case is the the later, what would the recommended method be for keeping it up to date?

Users Table
-id
-name
-email

Question Table
-id
-text
-poster (user id)

Responses Table
-id
-text
-question (question id)
-poster (user id)

Votes Table
-id
-response (response id)
-voter (user id)
  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-27T14:52:49+00:00Added an answer on May 27, 2026 at 2:52 pm

    De-normalizing the database model so a few critical scenarios can have better performance is justified, as long as you do it in a careful and deliberate fashion.

    So after you have benchmarked the realistic amount of data and determined that counting votes on the fly causes performance problems, go right ahead and cache the vote count.

    Probably the most robust way to keep the cached value up-to-date is to implement a database trigger that increments the cached value whenever a row is inserted into Votes and decrements it when a row is deleted.

    (NOTE: Having a SELECT COUNT(*)... trigger can introduce subtle concurrency issues.)

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a multi-table query, similar to this (simplified version) SELECT columns, count(table2.rev_id) As
This is a simplified version of the original problem. I have a class called
This is the simplified version of the problem: We have a table on an
This is a simplified version of my database, with the actual problem applied to
This is a simplified version of a query I have. Say for each customer
Here is a simplified version of my database model. I have two tables: Image,
I have two data structure classes (this is a simplified version of my code)
This is a simplified partial version of my code to demonstrate the issue: function
This is a (very) simplified version of my iPhone code : @interface x {
I have code like this (simplified): def outer(): ctr = 0 def inner(): ctr

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.