Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

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

Теперь моя проблема в том, что я не могу преобразовать эту модель результата из хранимой процедуры, которая имеет сложный возвращаемый тип, в мою модель представления. Может ли кто-нибудь помочь мне в ее решении.

Я приложил свои работы по проекту ниже,

Это автоматически сгенерированный контекст моделью ADO .net Entity.

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

Функция редактирования в импорте функций браузера модели

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

Показать результат, который генерируется автоматически.

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

Это то, что я пытаюсь сделать

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

И это ошибка, которую я получаю

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

Вот как моя модель представления состоит из

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

Запрос хранимой процедуры (Mysql)

Как преобразовать объектную модель результата в настраиваемую модель представления в asp .net MVC 5

вы должны предоставить сопоставление для вашего ViewModel в .Select() как:var query = objEmployee.sp_display().Select(s=>new ViewModel{employees=new employee{//add the mapping properties here},employee_detail = new employee_detail{//add the mapping properties here}}).ToList().

vikscool 16.07.2019 06:58

@vikscool, не могли бы вы показать мне пример для добавления местоположения свойств сопоставления, у меня есть имя и отдел в таблице сотрудников, а также адрес и мобильный телефон в сведениях о сотруднике?

Jawahar05 16.07.2019 07:17
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
2
1 735
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Как упоминалось в комментарии OP, схема employee и employee_details выглядит примерно так:

public class employee
{
    public string Name {get;set;}
    public string Department {get;set;}
}

public class employee_details
{
    public string Address {get;set;}
    public string Mobile {get;set;}
}

Итак, после применения сопоставления ваш код будет выглядеть примерно так:

var query = objEmployee.sp_display().Select(s=> new ViewModel{
employees = new employee{
 Name = s.Name //change the s.Name to the property name coming from your SP(if different)
 Department = s.Department
},
employee_detail = new employee_detail{
  Address = s.Address,
  Mobile = s.Mobile
}}).ToList()

Или лучше просто удалить объект query и использовать listEmployeeList, поскольку сам этот список также ссылается на ViewModel, поэтому объект query не нужен (если вы не хотите делать на нем какую-то другую фильтрацию):

listEmployeeList = // the above code with .ToList();

Как показано выше на третьем изображении, свойства не записаны, если хранимая процедура возвращает значение. Поскольку он генерируется автоматически, любые будущие изменения будут перезаписаны, если мы определим свойства вручную, хотя я определил его вручную, назначив номер списка индексов «listEmployeeList», но он не хранит никакого значения, он просто отображает нулевое значение . Я пропустил какое-либо сопоставление во время создания модели?

Jawahar05 16.07.2019 08:43

Он будет отображать ноль, поскольку у вас нет свойств, определенных в классе sp_display_result. Если столбцы могут измениться из Procedure, то класс ViewModel также должен измениться. Итак, лучше предоставить свойства сопоставления в классе sp_display_result. В противном случае используйте DataTable для сбора данных, а затем преобразуйте их в json и передайте клиенту/дескриптору в бизнес-логах для поддержки сопоставления.

vikscool 16.07.2019 09:59

Поскольку в процедуре нет входного параметра, как сопоставить с помощью sp_display_result? Есть ли способ сопоставить.

Jawahar05 16.07.2019 11:11

Другие вопросы по теме