Как связать данные из разных SQL таблиц, используя выпадающий список? - PullRequest
0 голосов
/ 17 апреля 2020

Я пытаюсь создать ASP. NET Core 3.1 MVC веб-приложение с использованием идентификатора. В приложении есть пользователи и администратор. Администратор может создавать новые задачи и назначать их пользователям.

Я получаю список пользователей и задач в 2 разных выпадающих списках следующим образом:
Вид: Assign.cs html

@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; }
}

Я получил ошибку, которая ранее запрашивалась в стеке потока : здесь и я попробовал решение. Я добавил закомментированную строку в Assign.cs, но результат, который я получаю, не тот, который я хочу. Идея состоит в том, чтобы сохранить Id пользователя из AspNetUser и taskId из таблицы задач в третьей таблице с именем Assign. Вот как это выглядит:

assign
Я новичок в этом, поэтому я не совсем понимаю, как это работает. Буду очень признателен за вашу помощь! Спасибо!
Редактировать Я внес изменения в приведенный выше код и также установил для Identity Specification значение Yes для первичного ключа. Он работает и записывает идентификатор пользователя и соответствующий идентификатор задачи в базу данных. Сейчас я пытаюсь создать что-то вроде:

@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'.

1 Ответ

0 голосов
/ 18 апреля 2020

В строке HTTP-сообщения вы отправляете Assign (модель объекта)

Контроллеру, поэтому состояние модели будет выполнено для класса Assign,

Я думаю, вы должны использовать AssignViewModel там, потому что все взаимодействие с представлениями должно происходить с viewmodel, если ваша модель представления действительна, то скрыть фактическую сущность.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...