c# - 比赛 : Storing an arbitrary number of fields

标签 c# javascript asp.net database-design

我将在当前工作的网站上创建竞赛。每个比赛都不会相同,并且可能有不同数量的输入字段,用户必须输入这些字段才能成为比赛的一部分,例如。

比赛 1 可能只需要一个名字

比赛 2 可能需要名字、姓氏和电子邮件地址。

我还将构建一个工具来观察这些条目,以便我可以查看每个单独的条目。

我的问题是存储任意数量字段的最佳方式是什么?我在考虑两种选择,一种是将每个条目写入包含所有比赛条目的 CSV 文件,另一种是在数据库中有一个带有 varchar 字段的 db 表,它只将整个条目存储为文本。这两种方式看起来都很乱,请问这种任务有什么通用的做法吗?

理论上我可以为每个可能的字段创建一个包含一列的数据库表,但是当比赛有特定要求时它不会工作,例如“用 100 个词告诉我们为什么......”或“输入你最喜欢的 5 个那些……”

已回答:

我决定使用下面描述的方法,其中有多个通用列可用于每个比赛的不同目的。

最初我打算使用 EAV,但我仍然认为它可能更适合这种特定场景。但通常不建议使用它,因为它的可扩展性差且查询复杂,而且我不想养成使用它的习惯。这两个答案在我的测试中都非常有效。

最佳答案

我认为您对 EAV 保持谨慎是正确的,因为它会使您的代码更复杂一些,并且对表进行临时查询会更困难一些。

我见过许多企业应用程序只是采用类似以下架构的东西 -

t_Comp_Data
-----------    
CompId  
Name  
Surname  
Email 
Field1 
Field2 
Field3 
... 
Fieldn

在这种情况下,通用字段(Field1 等)对于不同的比赛有不同的含义。为了便于查询,您可以为每个比赛创建一个不同的 View ,并使用适当的字段名称别名。

关于c# - 比赛 : Storing an arbitrary number of fields,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10476130/

相关文章:

javascript - 从更新中排除 NPM 包

c# - 母版页内容页面中禁用 Javascript NoScript 标记

asp.net - ASP MVC - 捆绑创建目录路径而不是文件路径

c# - 如何对 MVC ASP.Net 返回正确的 View 进行单元测试?

c# - POST 提交的表单显示 URL 中的值。难道不应该把他们藏起来吗?

c# - 使用 UserManager 预先加载

Javascript - 一次性替换字符串的多个部分

c# - X文档 : saving XML to file without BOM

javascript - 反向选择器 jQuery

asp.net - 什么时候会调用 InitializeCulture