我有一个项目来创建一个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,则可以存储空值.但如果你想要更多呢?这是单表模型开始分崩离析的时候.你现在开始认为一个问题真的可以有一个或多个选择,并且想要分成父子表…现在你做出了明智的决定;-)