Squeak.ru - шаблоны программирования

ViewModel. Загрузите запрос LINQ для просмотра

Я использую EF 6, и мне нужен запрос LINQ для извлечения всех данных в мою ViewModel. Каждое событие имеет статус (один к одному) В таблицах нет FK

Я хочу отображать что-то вроде этого:

EventID   EventStatusID   Name      EventDate   EventDesc    
99        1               Allowed   2000-1-1    Music festival

Класс ViewModel:

public class EventVM : Event
{
    public EventStatus EStatus { get; set; }
}

Класс события:

[Serializable]
public class Event
{
    public int EventID { get; set; }
    public int EventStatusID { get; set; }
    public string EventNumber { get; set; }
    public DateTime EventDate { get; set; }
    public string EventDesc { get; set; }
}

Класс статуса события:

[Serializable]
public class EventStatus
{
    public int EventStatusID { get; set; }
    public string Name{ get; set; }
    public string Desc{ get; set; }
}

Таблица событий:

dbo.Event

    Column name     Type       Allow nulls
PK  Eventid         int        no
    Eventstatusid   int        no
    Eventnumber     nvarchar   no
    Eventdate       date       no
    Eventdesc       nvarchar   no

Таблица состояния событий:

dbo.EventStatus

    Column name     Type       Allow nulls
PK  Eventstatusid   int        no
    Desc            nvarchar   no
    Name            nvarchar   no

Я застрял в этом моменте:

            var viewModel =
           (from ev in db.Events
            join evs in db.EventStatus on ev.EventStatusID equals evs.EventStatusID
            where ev.EventStatusID == id

            select new EventVM
            {
                EventID = ev.EventID
            }).First();

с ошибкой:

System.NotSupportedException: «Сущность или сложный тип «ModelEvent.EntityFramework.Concrete.EventVM» не может быть создан в запросе LINQ to Entities».

Я не могу изменить модель просмотра, я должен использовать эту


  • Просто выберите анонимный тип, а затем создайте модель. 28.07.2017
  • Или сделайте так, чтобы класс модели представления не наследовался от Event 28.07.2017

Ответы:


1

Вам нужно создать модель или использовать анонимный тип для сбора данных из БД (не забудьте использовать ToList() для фактического сбора данных), а затем сопоставить ее свойства в свойства файла EventVM. Вы получаете эту ошибку, потому что EF не может правильно создать экземпляр EventVM.

28.07.2017
Новые материалы

Угловая структура архитектуры
Обратите внимание, что эта статья устарела, я решил создать новую с лучшей структурой и с учетом автономных компонентов: https://medium.com/@marekpanti/angular-standalone-architecture-b645edd0d54a..

«Данные, которые большинство людей используют для обучения своих моделей искусственного интеллекта, поставляются со встроенным…
Первоначально опубликовано HalkTalks: https://hacktown.com.br/blog/blog/os-dados-que-a-maioria-das-pessoas-usa-para-treinar-seus-modelos-de-inteligencia-artificial- ja-vem-com-um-vies-embutido/..

Сильный ИИ против слабого ИИ: различия парадигм искусственного интеллекта
В последние годы изучению и развитию искусственного интеллекта (ИИ) уделяется большое внимание и прогресс. Сильный ИИ и Слабый ИИ — две основные парадигмы в области искусственного интеллекта...

Правильный способ добавить Firebase в ваш проект React с помощью React Hooks
React + Firebase - это мощная комбинация для быстрого и безопасного создания приложений, от проверки концепции до массового производства. Раньше (знаете, несколько месяцев назад) добавление..

Создайте API с помощью Python FastAPI
Создание API с помощью Python становится очень простым при использовании пакета FastAPI. После установки и импорта вы можете создать приложение FastAPI и указать несколько конечных точек. Каждой..

Веселье с прокси-сервером JavaScript
Прокси-серверы JavaScript — это чистый сахар, если вы хотите создать некоторую общую логику в своих приложениях, чтобы облегчить себе жизнь. Вот один пример: Связь клиент-сервер Мы..

Получить бесплатный хостинг для разработчиков | Разместите свой сайт за несколько шагов 🔥
Статические веб-сайты — это веб-страницы с фиксированным содержанием и его постоянным содержанием. Но теперь статические сайты также обрабатывают динамические данные с помощью API и запросов...