首页 > 解决方案 > 映射属性“角色”(用户表中的外键)与角色表 dotNet Core

问题描述

我试图通过为他们设置角色来创建用户。
角色属性是用户类中的一个必填字段。
问题是当我做了一个标记以从角色表中检索数据以便能够将角色设置给用户时,插入查询不起作用。用户表具有属性“roleId”,但用户类具有角色类的“角色”属性。

我将把 UserCreate Razor 页面的代码与我使用的模型放在一起。

用户创建.cshtml:

@page
@model SprintOneBack.UserCreateModel

@{
    ViewData["Title"] = "UserCreate";
}

<h1>Create</h1>

<h4>User</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form method="post">
            <div asp-validation-summary="ModelOnly" class="text-danger"></div>
            <div class="form-group">
                <label asp-for="User.Nom" class="control-label"></label>
                <input asp-for="User.Nom" class="form-control" />
                <span asp-validation-for="User.Nom" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.Email" class="control-label"></label>
                <input asp-for="User.Email" class="form-control" />
                <span asp-validation-for="User.Email" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.password" class="control-label"></label>
                <input asp-for="User.password" class="form-control" />
                <span asp-validation-for="User.password" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.role" class="control-label"></label>
                <select asp-for="User.role" class="form-control" asp-items="@(new SelectList(Model.displayRoles, "Id", "Label"))">
                    <option value="" selected disabled>-- select Role --</option>
                </select>
                @*<input asp-for="User.role.Label" class="form-control" />*@
                <span asp-validation-for="User.role" class="text-danger"></span>
            </div>
            <div class="form-group">
                <input type="submit" value="Create" class="btn btn-primary" />
            </div>
        </form>
    </div>
</div>

<div>
    <a asp-page="Index">Back to List</a>
</div>

@section Scripts {
    @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}
}

用户创建模型.cshtml.cs:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.AspNetCore.Mvc.Rendering;
using Microsoft.EntityFrameworkCore;
using SprintOneBack.Model;

namespace SprintOneBack
{
    public class UserCreateModel : PageModel
    {
        private readonly ApplicationDbContext _context;

        public UserCreateModel(ApplicationDbContext context)
        {
            _context = context;
            displayRoles = _context.Role.ToList();
        }

        public IActionResult OnGet()
        {
            return Page();
        }

        public IEnumerable<Role> displayRoles { get; set; }

        public async Task OnGetRoles()
        {
            displayRoles = await _context.Role.ToListAsync();
        }

        [BindProperty]
        public User User { get; set; }

        public async Task<IActionResult> OnPostAsync()
        {
            if (!ModelState.IsValid)
            {
                return Page();
            }

            _context.User.Add(User);
            await _context.SaveChangesAsync();

            return RedirectToPage("./UserIndex");
        }
    }
}

用户类:

public class User
{
    [Key]
    public int Id { get; set; }
    [Required]
    public string Nom { get; set; }
    [Required]
    public string Email { get; set; }
    [Required]
    public string password { get; set; }
    [Required]
    public Role role { get; set; }
}

角色类:

public class Role
{
    [Key]
    public int Id { get; set; }
    [Required]
    public string Label { get; set; }
}

用户表和角色表: 在此处输入图像描述

标签: c#razor-pagesasp.net-core-3.0razor-pages-crud

解决方案


我将属性 roleId 添加为整数,并指定它是 User 表中的列 roleId ,并保留角色属性(因此 ef 知道角色表中有一个外键)并重新生成表。当我重新生成剃须刀页面时,我有一个漂亮的 select html 标记来列出每个用户的数据库中的所有角色。

代码现在看起来像这样:

public class User
{
    [Key]
    public int Id { get; set; }
    [Required]
    public string Nom { get; set; }
    [Required]
    public string Email { get; set; }
    [Required]
    public string password { get; set; }
    [Column("roleId")]
    public int roleId { get; set; }
    public Role role { get; set; }
}

创建用户.cshtml:

<h4>User</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form method="post">
            <div asp-validation-summary="ModelOnly" class="text-danger"></div>
            <div class="form-group">
                <label asp-for="User.Nom" class="control-label"></label>
                <input asp-for="User.Nom" class="form-control" />
                <span asp-validation-for="User.Nom" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.Email" class="control-label"></label>
                <input asp-for="User.Email" class="form-control" />
                <span asp-validation-for="User.Email" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.password" class="control-label"></label>
                <input asp-for="User.password" class="form-control" type="password" />
                <span asp-validation-for="User.password" class="text-danger"></span>
            </div>
            <div class="form-group">
                <label asp-for="User.roleId" class="control-label"></label>
                <select asp-for="User.roleId" class ="form-control" asp-items="ViewBag.roleId"></select>
            </div>
            <div class="form-group">
                <input type="submit" value="Create" class="btn btn-primary" />
            </div>
        </form>
    </div>
</div>

推荐阅读