使用C#/ ASP.net MVC建模NoSQL论坛应用程序
我目前正在开发一个基于论坛(问题/答案)的应用程序。
使用C#ASP.net MVC和MongoDB进行数据存储。
我正在看模型。
我想要有这样的单独的类:(简化)
public class Question { public string ID { get; set; } public string Title { get; set; } public string Body { get; set; } public List Tags { get; set; } public DateTime DateCreated { get; set; } public string ForumID { get; set; } }
回答
public class Answer { public string ID { get; set; } public string QuestionID { get; set; } public string Body { get; set; } public DateTime DateCreated { get; set; } }
我的问题是:
如何处理“回复”
我最好拥有(如上面的模型中)两个独立的“实体”
或者我的问题模型中是否应该有一个答案列表?
一些要求是我需要能够显示答案的数量等…
将它存储在NoSQL数据库中,我知道我应该对事物进行反规范化,但是如何在不检索整个post的情况下插入答案呢? 使用NoRM和MongoDB可以实现这种操作吗?
通常在MongoDB中,您可以在问题中嵌入答案。 99%的时间你会按问题查询,所以你也可以同时获得答案。
一些要求是我需要能够显示答案数……
如果你带回问题的答案,这真的很容易。 你将有一个包含答案的数组/列表/集合。 所以你只需抓住长度。
但是如何在不检索整个post的情况下插入答案
MongoDB支持primefaces“$ push”操作。 这意味着您可以将项添加到数组,而无需从客户端实际加载文档。 从javascript shell,它看起来像这样:
db.questions.update( {_id : your_id}, { $push : { answers : your_answer_object } } );
所以MongoDB能够做到这一点。 你必须检查NoRM驱动程序,以确保它们实际上允许这种类型的行为(如果它们不支持$ push,它们真的会丢失一些东西)。
答案应该是问题的一部分。
public class Question {public string ID {get; 组; }
public string Title { get; set; } public string Body { get; set; } public List Tags { get; set; } public DateTime DateCreated { get; set; } public string ForumID { get; set; } public List Answers { get; set; } }
由于缺少连接,文档数据库鼓励您将整个图形的实例存储在一个文档中。