如何使用下拉菜单绑定来自不同SQL表的数据?

问题描述 投票:0回答:1

我正在尝试使用身份创建ASP.NET Core 3.1 MVC Web应用程序。该应用程序具有用户和管理员。管理员可以创建新任务并将其分配给用户。

我通过2个不同的下拉列表获取用户和任务的列表,如下所示:查看:Assign.cshtml

@model TaskManager2.ViewModels.AssignViewModel

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

<h1>Assign</h1>

<h4>Assign</h4>
<hr />
<div class="row">
    <div class="col-md-4">
        <form asp-action="Assign">
        <div class="form-group">
            @Html.DropDownListFor(t => t.TaskId,
            Model.Tasks, "--Select task--")
        </div>
        <div class="form-group">
            @Html.DropDownListFor(u => u.Id,
            Model.Users, "--Select user--")
        </div>
            <div class="form-group">
                <input type="submit" value="Create" class="btn btn-primary" />
            </div>
        </form>
    </div>
</div>

AdminController:

private readonly ApplicationDbContext _context;
    public AdminController(ApplicationDbContext context)
    {
        _context = context;
    }
    public IActionResult Index()
    {
        return View();
    }
    public IActionResult Assign()
    {
        var users = (from u in _context.Users select new SelectListItem { Value = u.Id, Text = u.FirstName }).ToList();
        var tasks = (from t in _context.Task select new SelectListItem { Value = t.TaskId.ToString(), Text = t.Description }).ToList();

        var user = _context.Users.FirstOrDefault();
        return View(new AssignViewModel { Users = users, Tasks = tasks });
    }
    [HttpPost]
    [ValidateAntiForgeryToken]
    public async Task<IActionResult> Assign([Bind("TaskId, Id")] Assign assign)
    {
        if (ModelState.IsValid)
        {
            _context.Add(assign);
            await _context.SaveChangesAsync();
            return RedirectToAction(nameof(Index));
        }
        return View(assign);
    }

ViewModel:

public class AssignViewModel
{
    public IList<SelectListItem> Tasks;
    public IList<SelectListItem> Users;
    //public long SelectedUserId { get; set; }
    //public long SelectedTaskId { get; set; }
    //Added these lines instead
    public Task TaskId { get; set; }
    public IdentityUser Id { get; set; }
}

型号:Assign.cs

public partial class Assign
{
    public long AssignId { get; set; }
    public long TaskId { get; set; }
    //[DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public string Id { get; set; }
}

我收到一个先前在stackoverflow上询问的错误:here,我尝试了解决方法。我在Assign.cs上添加了注释行,但是得到的结果不是我想要的结果。这个想法是将AspNetUser中的用户ID和Task表中的taskId保存在名为Assign的第三个表中。它是这样的:

assign我对此并不陌生,所以我不太了解它是如何工作的。我将衷心感谢您的帮助!谢谢!编辑我对上面的代码进行了更改,并将主键的身份规范设置为“是”。它可以工作并将用户ID和相应的taskId记录到数据库中。现在,我正在尝试创建类似的内容:

@if ((bool)ViewData["HasError"]) //not working
{   <div class="alert alert-danger" role="alert">

        Please select!
    </div>
}

如果用户未选择任何选项而不是抛出此错误,则会发出警报:

[InvalidOperationException:传递到ViewDataDictionary的模型项的类型为'TaskManager2.Models.Assign',但是此ViewDataDictionary实例需要类型为'TaskManager2.ViewModels.AssignViewModel'的模型项。

c# sql-server asp.net-mvc asp.net-core dropdown
1个回答
© www.soinside.com 2019 - 2024. All rights reserved.