c# - 映射属性“角色”(用户表中的外键)与角色表 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; }
}
用户表和角色表:
解决方案
我将属性 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>
推荐阅读
- mysql - Cube JS中的左外连接
- php - Wordpress Posttype 功能
- c++ - 当需要完整类型时,C++ 中模板的循环引用
- reactjs - Commerce JS API 拒绝我的测试交易
- c++ - 简单的顺序 std::iota 比并行等效更快
- java - 在 spring-boot:run 期间启动 MockServer
- ruby - gem install puma -v '4.3.7' 在 Mac OS Big Sur Ruby 2.6.3 Bundler 版本 2.2.19 上失败
- sql - SQLite:相当于“软删除”的 ON DELETE RESTRICT(表字段变为非 NULL)
- volttron - 通过 rpc 从外部应用程序调用 VOLTTRON 代理功能
- django - Django Crispy Forms 未按预期工作