4

我已经开始学习 MVC3 开发并且遇到了一些绊脚石。在我的项目中,我将默认的 aspnet_ 成员表移到了单独的 SQL Server 2008 Express 数据库中。然后我添加了自己的表格来保存额外的配置文件数据。我现在想构建一个视图,其中将列出用户名(来自 aspnet_Users)、电子邮件地址(来自 aspnet_Membership)、名字和姓氏(来自自定义构建表 UserDetails,用户 ID 为 PK 和 FK 到 aspnet_Users)和用户角色( aspnet_UsersInRoles 和 aspnet_Roles)。

到目前为止,要从我的数据库中读取和写入,我已经为每个自定义构建的表构建了模型,其中包含一个 dbcontext 类:

    public class UserDetail
{

    [Key]
    public Guid UserId { get; set; }

    public string FirstName { get; set; }

    public string LastName { get; set; }

    public string Address { get; set; }

    public string City { get; set; }

    public string State { get; set; }

    public string Zip { get; set; }

    public string Phone { get; set; }

    public DateTime DateUpdated { get; set; }
}

public class UserLinkToken
{
    [Key]
    public Guid UserId { get; set; }

    public string LinkToken { get; set; }

    public DateTime DateUpdated { get; set; }
}

public class ProShotDB : DbContext
{
    public DbSet<UserDetail> UserDetails { get; set; }
    public DbSet<UserLinkToken> UserLinkTokens { get; set; }
}

我不得不为我的应用程序命名我的表“UserDetails”和“UserLinkTokens”来编写和更新我的数据库,当模型和 dbcontext 的名称与我的数据库和表名不匹配时,应用程序最终会创建另一个数据库表并在那里写入数据。

据我所知,发送一个对象以查看aspnet_表中的属性和我的自定义表中的属性,我将想要构建一个ModelView。在阅读了大量模型视图示例后,我仍然不清楚它应该如何查找我的应用程序。

有人可以给我一个模型视图的例子,我可以用它来显示数据行列表并更新模型视图中给定用户 ID 引用的所有相应表列吗?

例如,假设我只想查看所有 FirstNames(UserDetails 表)及其相应的电子邮件(aspnet_Membership)。

我的最终目标是一个视图,它将显示具有分配角色的用户。列出的每个用户都有一个链接,该链接将指向一个控制器,如果他们当前不属于该角色,则该控制器会将他们分配为管理员,如果他们当前是管理员,则删除管理员角色。

抱歉,如果此类问题之前已在其他问题中回答过。我读过不少,觉得他们应该回答了我的问题,但似乎没有一个完全匹配。我的困惑很可能源于没有完全理解我的应用程序是如何连接到我的数据库的。我有点理解我的模型代表表的一行数据,dbcontext 采用一组这些数据行模型并将其连接到数据库中的表 (dbset<(datarow/model object)> (table of datarows /一组模型对象))。由于我没有看到 aspnet_ 表/模型对象的 dbcontext 类,因此我对如何检索、更新或写入这些表中的数据没有很好的概念。

感谢您帮助消除我对它如何工作的无知或给我一个如何完成我需要的简单示例。

4

2 回答 2

1

首先,它被称为 View Model,而不是 ModelView。视图模型只是一个为视图目的而定制的类。它通常只包含该视图所需的数据,并包含诸如数据注释之类的东西来处理验证和表示。

因此,您只需创建一个模型,其中包含您希望在视图中显示的所有数据。这就是构建视图模型的全部内容。

所以你的视图模型只是

public class MyViewModel {
    public string FirstName {get;set;}
    public string Email {get;set;}        
}

然后在您看来,您只需执行以下操作:

@model MyViewModel

@using(Html.BeginForm()) {
    @Html.EditorForModel()
    <input type="submit" />
}

在您的控制器中(或者更好的是,在业务层中)您只需执行查询以检索用户名和电子邮件,然后将查询结果中的值复制到视图模型中。

当您更新数据时,您执行相反的操作。这确实是一个太大的概念,但无法在这样的帖子中讨论。您应该真正查看示例代码,例如 MVC Music Store 或 Nerd Dinner。

重要的事情要记住。会员资格是与您的其他表格完全分开的系统。您必须单独检索它们,并单独更新它们。使用 Membership API 更新会员电子邮件或其他详细信息,并使用您自己的表格更新您的数据。

于 2012-10-22T02:22:25.860 回答
0

好吧,我决定我真正需要的只是会员资格,所以我放弃了尝试包括名字和姓氏。

我的视图模型:

namespace Pro_Shot_Portal.ViewModels
{
    public class SetAdminViewModel
    {
        public string UserName { get; set; }
        public string Email { get; set; }
        public string[] Role { get; set; }
    }
}

我的控制器:

    [Authorize(Roles = "Administrator")]
    public ActionResult SetRoles()
    {

        var model = Membership
            .GetAllUsers()
            .Cast<MembershipUser>()
            .Select(x => new SetAdminViewModel
                {
                    UserName = x.UserName,
                    Email = x.Email,
                    Role = Roles.GetRolesForUser(x.UserName)
                });
        return View(model);
    }

    [Authorize(Roles = "Administrator")]
    public ActionResult AddAdmin(string username)
    {
        Roles.AddUserToRole(username, "Administrator");

        return RedirectToAction("SetRoles", "Account");
    }

    [Authorize(Roles = "Administrator")]
    public ActionResult RemoveAdmin(string username)
    {
        Roles.RemoveUserFromRole(username, "Administrator");

        return RedirectToAction("SetRoles", "Account");
    }

我的观点:

@model IEnumerable<Pro_Shot_Portal.ViewModels.SetAdminViewModel>

@{
    ViewBag.Title = "Set Roles";
}

<h2>Index</h2>

<table>
    <tr>
    <td>UserName</td>
    <td>Email</td>
    <td>Roles</td>
    </tr>

@foreach (var item in Model) {
    <tr>
        <td>
            @Html.DisplayFor(modelItem => item.UserName)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.Email)
        </td>
        <td>
            @Html.DisplayFor(modelItem => item.Role)
        </td>

        <td>
            @if (@Html.DisplayFor(modelItem => item.Role).ToString() == "Administrator")
            {
                @Html.ActionLink("Remove Admin", "RemoveAdmin", new { username = item.UserName })
            }
            else
            {
                @Html.ActionLink("Add Admin", "AddAdmin", new { username = item.UserName })
            }
        </td>
    </tr>
}

</table>

这看起来对我有用。

感谢您帮助我走上正确的道路 Mystere。另外,如果我的代码看起来有问题,请告诉我。

于 2012-10-23T01:41:02.247 回答