数据库设计 – 多选测验引擎的数据库模式的优秀设计是什么?

前端之家收集整理的这篇文章主要介绍了数据库设计 – 多选测验引擎的数据库模式的优秀设计是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个项目来创建一个asp.net mvc网站来生成一个测验.
这是规范:

>对于访问该网站的每个用户,她/他都会得到一个测验.
>每个测验都包含一些多项选择问题.
>每个问题都包含一个问题和5个相互排斥的选择.

我能想到的最简单的模型如下:

public class Problem
    {
        public int ProblemId { get; set; }
        public string Question { get; set; }
        public string A { get; set; }
        public string B { get; set; }
        public string C { get; set; }
        public string D { get; set; }
        public string E { get; set; }
    }

我不确定它是好的.
你能给我一个更好设计的建议吗?

解决方法

简单直观的设计总是最好的,因为它们非常简单,我们开始怀疑自己;-).你做得很好,除了你也可以用问题本身存储正确的答案.然后它不再仅仅是一个问题.所以现在是ProblemAndAnswer或QuizItem.

所以这可以作为多列存储在单个表中.但你还需要了解它的含义.这意味着您假设一个问题总是有5个选择.如果你的数量少于5,则可以存储空值.但如果你想要更多呢?这是单表模型开始分崩离析的时候.你现在开始认为一个问题真的可以有一个或多个选择,并且想要分成父子表…现在你做出了明智的决定;-)

猜你在找的MsSQL相关文章