Skip to content
This repository has been archived by the owner on Apr 13, 2021. It is now read-only.
/ dotNetOrmTest Public archive

Test data-access-layer with specifications and fetch strategies on entity framework core

Notifications You must be signed in to change notification settings

mt89vein/dotNetOrmTest

Repository files navigation

EFCoreDAL - Data access layer on entity framework core 2.1.1

Описание тестовой предметной области:

Абстрактный базовый класс Document, с коллекцией вложенных файлов (Attachments) и одним наследником OtherDocument. OtherDocument, конкретный класс, имеющий 2 коллекции: Items, Payments. Коллекция Items имеет вложеную коллекцию NestedItems, которая в свою очередь имеет коллекцию OneMoreNestedItems

  • Document

    • Attachments[]

    • OtherDocument

      • Payments[]

      • Items[]

        • NestedItems[]

          • OneMoreNestedItems[]

Основная цель проекта - реализовать следующее:

  • Table per type

  • Complex types

  • ~~~Lazy load~~~

  • Eager load

  • Specifications in access layer

  • Fetch / Update strategy

  • Caching in Redis

Не решенные проблемы:

  • Текущая реализация не позволяет указать предикаты для вложенных сущностей и как следствие невозможность фильтровать по ним (only not deleted etc), вероятно для этого требуется инжектить сервисы этих сущностей и запрашивать данные через них.

Например если необходимо забрать OtherDocument с OtherDocumentItems, то сервис OtherDocument.Get() должен принимать настройки для запроса OtherDocumentItems, и в реализации использовать сервис по работе с OtherDocumentItems, после чего полученные данные передать и дополнить сущность. Таким образом, сущности с подобным поведением должны иметь методы для заполнения полей, которые запрашиваются отдельно.

About

Test data-access-layer with specifications and fetch strategies on entity framework core

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages