查看模型:数据复制VS性能

时间:2013-11-17 06:15:55

标签: asp.net-mvc entity-framework asp.net-mvc-4

我正在学习MVC并且有一个想法,我想请一些意见。

我正在创建一个简单的社交网络来学习MVC。有用户和帖子。每个用户的墙上都有很多帖子(来自他们自己和其他用户)。这些是我的域模型

**USER**
UserID
Username
First Name
Second Name
WallID

**POST**
PostID
WallID (id of user who's wall has been posted to)
UserID (user who posted)
PostConent

现在我试图了解viewmodels。我不认为我理解他们,从我目前理解的情况来获取帖子作者的用户信息我将制作两个新模型来组合页面上的数据:

**POSTExtended**
PostID
WallID (id of user who's wall has been posted to)
UserID (user who posted)
PostConent
Username
FirstName
SurName

**WallViewModel**
PostExtended postExtended = new PostExtended
User user = new User

现在我不知道如何填充这个。我现在最好的猜测听起来会起作用 - 但肯定听起来不对劲!

我会创建一个绑定到wallViewModel的控制器。

然后我会查询数据库以获取相关WallID的所有帖子并将它们存储在对象列表中。

然后我会使用foreach循环查询列表中每个帖子的users表 - 获取该PostID的用户名和用户名,并将它们添加到新的PostExtended对象(使用原始帖子中的其他数据)对象),并将它们存储在postExtended对象列表中。

然后我会点击DB获取wallViewModel的用户对象(帖子所属的用户所在的用户),这样我就可以在标题等中显示他们的名字等。

然后我会添加用户对象并将PostExtended对象列表添加到WallViewModel对象。并将该对象发送到视图。

现在这对我来说听起来不对,因为据我所知,这意味着每个帖子都会在数据库中单独一次获取用户名。

请有人对此有所了解。听起来必须有一个更简单的方法来做到这一点! (如果这是正确的方法,那么只是在posts表中复制数据以保存每次循环中的数据都会更好吗?)。

希望这是可以理解的!感谢

2 个答案:

答案 0 :(得分:3)

视图模型是一种组合不同数据源并将自定义信息发送到视图的方法。在这种情况下,您需要的是一个只有一个用户但有一个帖子列表的模型。像这样的东西

** WallViewModel **
User user
List<User> userList
List<Post> posts
通过这种方式,您拥有该用户的所有帖子,但用户信息只有一次而且没有重复。如果您有任何问题,请告诉我

编辑:

我现在明白了。由于每个页面上有多个用户和多个帖子,我会发送页面所有者(单个)和页面上有帖子的用户列表。然后遍历帖子并从帖子上的用户ID中选择来自userList的相应用户信息。希望这有助于

答案 1 :(得分:2)

添加到Matt Bodily的回答中,您的ViewModel将类似于:

public class LoggedInUserViewModel
{
   property int UserId;
   property string UserName;
   property List<ViewModelPosts> Posts;
}

public class ViewModelPosts
{
   property int AuthorUserId;
   property string AuthorName;
   property string Message;
   property DateTime CreatedDate;
}

在您的控制器中,您只需创建一个LoggedInUserViewModel的新实例,并使用数据库调用和post / messages的foreach循环正确填充它。 foreach的每次迭代都将创建一个ViewModelPosts的新实例,并将该填充的实例添加到LoggedInUserViewModel List属性中。

可以直接将模型类传递给View,但这不能很好地适应Views上下文。 View正在寻找/期望以更有意义的方式组合数据库中的数据,因此ViewModels通过组合彼此相关的模型类,帮助在模型/数据库的基本结构和View所需的更复杂结构之间进行此转换。在您的控制器中有一种有意义的方式,而您的View无需了解数据库/模型中的实际数据关系。