Want to win a PS4? Go Premium and enter to win our High-Tech Treats giveaway. Enter to Win


Database Schema for Open Ended Questionnaire

Posted on 2013-05-17
Medium Priority
Last Modified: 2013-07-05
I want to create an open ended questionnaire feature on my Website.  Admins manage their own site and they can create open ended questions (like a survey) that include things like menus, radio buttons, input, textareas and checkboxes. (Standard stuff).

I've written the admin side so that these are created on the fly based on the admin set up.  So different sites can have different quantities of answers.  I'm now looking at the best ways of storing the user answers.  

So for each user, I need to record:

1) Their user ID
2) The questionnaire ID (which questionnaire they are on)
3) The answers to the questions (varying number of questions).

I see two ways of doing this:

1) A set up where each user has ONE record with three fields.
 - userID
 - questionnaireID
 - user response

The user response field is a text field that contains a serialized string with their answers.  

2) The second way is to set up a database where the schema is that there will be as many records for each user as there are questions.  So now we add a fourth field.

 - userID
 - questionnaire ID
 - question ID
 - single answer response

The advantage I see to the first method is a more compact database (i.e. less records).

The advantage to the second is that you can pull individual data for a particular question without having to un-serialized the whole record.

My question is this.  Is the efficiency gained by the first option any consideration?  Or does it make more sense to just use the second option even though it greatly increases the number of records in the database (e.g. If you have a questionnaire with 12 questions and 100 people answer it, option one means 100 records but option two goes right to 1200).

Any insight offered would be helpful.  Thanks.
Question by:pkonstan1
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
LVL 16

Accepted Solution

Surendra Nath earned 500 total points
ID: 39175494
I dont think even option 1 will save you a lot of database size, as when you serialize the  answers in a XML format (assuming it will be in XML), the one row will take almost same space as of the option 2.
So, if you are thinking of going to option 2 because of database size, think once again. it might not drastically reduce the size.

It really depends on the way your UI behaves, if your UI wants to get all the answers once from the DB and also sends all the answers of the questionaire once to the DB, then It is better to use the option 1 approach, as this will have less DB traffic and also will improve the performance.

if you are planning to retrive answer by answer for an user from UI, then option 2 will be more useful than option 1 as  you need not de-serialize the xml to object and find the question id in it.

But most of the questionaire sites will work, as I described in the point 1 above, so it would be good to go with option 1 not because of compact DB size, but becuase it will boost your performance and decreases the DB reads.

I hope this helps.
LVL 34

Assisted Solution

by:Brian Crowe
Brian Crowe earned 100 total points
ID: 39175724
Also keep in mind that at some point you might want to develop some metrics on individual questions (%correct, etc.) and this would be much easier to do with option 2.
LVL 20

Assisted Solution

by:Mark Brady
Mark Brady earned 100 total points
ID: 39176049
In the case of adding extra metrics it is still do-able with option 1. I would create an associate array and store each question/answer etc in there then json_encode it all and make one write to the database.
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

LVL 70

Assisted Solution

by:Scott Pletcher
Scott Pletcher earned 100 total points
ID: 39176081
Option 1 could be a maintenance nightmare.

As a questionnaire (q'aire for short) evolves over time, does each version of the q'aire get a different ID?  Or do you just add a revision#?

I would tend to use Option 2 and lock the question IDs: a given question and range of answers set is always a given q ID, that never changes.  Iow, the Q ids in the master q table are NOT serial based on the q'aire they are in, but are essentially independent entities that can appear in any q'aire.

Of course a given q'aire may assign a serial # -- q#1, q#2 -- to each master q id for that specific q'aire, but that is just for the sake of the q'aire, and does not change that qs core id in its master table.
LVL 16

Expert Comment

by:Surendra Nath
ID: 39176085
@elvin66, I believe, you want to caliculate the metrics at the application layer, where as @BriCrowe can do it at the database layer. Now which method is good or bad depends on which server (application server / database server) will be more free at that time plus the amount of memory consumption plus the performance (as per performance I think DB will outway application as in case of applcaiton, we have to retrive the whole data again into memory through network, this step is not required for DB case).

Author Comment

ID: 39177176
The way I avoid the "nightmare" is each question is given a unique ID (I call screen) and then a position indicator.  So if you need to insert a new question, it's ID may be out of sequence with position, but it's relationship is still maintained.  

On the topic of how most calculations are performed it is the first option where you read DB once to fill UI, then user manipulates data and it is saved back to the DB.

On the admin side to view the results, it follows a similar pattern.  The data is read from the DB for each entry and put into a table.  Then at the table label the information can be sorted and viewed.  If a change is made the entire record is put back in at once.

For most of these questionnaires it is rare that you'll need to do any type of mass manipulation of all records at once (e.g. Change everybody's blue answer to red).  And any queries that you do will be done in the table where you're viewing the data, not as a DB select.

Thanks for the input.  I'll leave open for a bit to allow any additional comments and then award points.

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

What if you have to shut down the entire Citrix infrastructure for hardware maintenance, software upgrades or "the unknown"? I developed this plan for "the unknown" and hope that it helps you as well. This article explains how to properly shut down …
There are times when I have encountered the need to decompress a response from a PHP request. This is how it's done, but you must have control of the request and you can set the Accept-Encoding header.
Viewers will learn how the fundamental information of how to create a table.
Viewers will learn how to use the SELECT statement in SQL and will be exposed to the many uses the SELECT statement has.
Suggested Courses

610 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question