Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
389 / 304 / 67
Регистрация: 10.07.2010
Сообщений: 802

Паттерн репозиторий. Основная концепция

15.05.2018, 14:47. Показов 1612. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, единого мнения не нашел касательно паттерна репозиторий. Интересно услышать мнение форумчан, то как у них это реализовано.
Предположим есть 3 таблицы User, UserComments, Article (есть статья, есть пользователи которые могут эту статью комментировать)

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

т.е примерно следующее:

C#
1
2
3
var article = _articleRepository.GetArticleByName(articleName);
var user = _userRepository.GetUserByLogin(userLogin);
var comments = _userCommentsRepository.GetCommentsByUserId(user.Id);
Имеем 3 запроса к базе.
Первый момент:
Может ли репозиторий содержать работу с несколькими таблицами объединенными общей областью. К примеру комментарии пользователей относятся к области "пользователи" - избавляемся от _userCommentsRepository. добавляем метод GetUserComments(userLogin) в репозиторий _userRepository

Второй момент:
Может ли репозиторий возвращать IQueryable тип или он должен возвращать всегда готовую коллекцию объектов.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.05.2018, 14:47
Ответы с готовыми решениями:

Почему паттерн абстрактная фабрика - паттерн уровня объектов, если в нём могут быть статические отношения?
Взято из Шевчук А., Охрименко Д., Касьянов А. Design Patterns via C#. Приемы объектно-ориентированного проектирования (2015): Почему...

EF Core и паттерн Репозиторий
В общем возник такой вопрос, есть общий репозиторий реализующий стандартные методы: Get,Insert,Update,Delete,GetAll, есть так же классы...

Unit test сервиса, принимающего как аргумент репозиторий, а репозиторий организован через mysql.connector Python 3
Всем привет. Теории много, примеров много, а как возьмешься, толку мало. Особенно из разряда, создается mock объект, в него что-то...

1
Unnamed
 Аватар для kingzfate
160 / 158 / 81
Регистрация: 09.06.2011
Сообщений: 852
15.05.2018, 15:07
zelen, не думаю что стоит создавать множество репозиториев, достаточно одного на контроллер со ссылкой в DOM
C#
1
2
3
4
5
6
7
8
9
10
11
[Authorize(Roles = "company")]
    [OutputCache(Duration = 0, VaryByParam = "none")]
    public class CountersController : Controller
    {
        IRepository _repository;
        IMapper _modelMapper;
        public CountersController(IRepository repository, IMapper modelMapper)
        {
            _repository = repository;
            _modelMapper = modelMapper;
        }
А уже в DOM
C#
1
2
3
4
5
namespace Domain.Concrete
{
    public partial class Repository : IRepository
    {
        Context ctx = new Context();
У которого есть общий интерфейс для всех методов
C#
1
2
3
4
5
6
namespace Domain.Abstract
{
    public interface IRepository
    {
        IEnumerable<T> GetAllEntity<T>() where T : class;
        Task EditEntityAsync<T>(T entity) where T : class;
И классы структуры с методами под определенные Areas (или в зависимости от того как структурировано ваше приложение)
Admin.cs
C#
1
2
3
4
5
6
7
8
9
10
11
namespace Domain.Concrete
{
    public partial class Repository
    {
        //--- Поиск компаний
        public List<Company> GetSearchedCompany(string searchTerm, int pageSize, int pageNum, out int totalResults)
        {
            var TopUserName = ctx.Company.Where(x => (x.Account + x.ShortName).ToLower().Contains(searchTerm.ToLower())).ToList();
            totalResults = TopUserName.Count;
            return TopUserName.Skip((pageNum - 1) * pageSize).Take(pageSize).ToList();
        }
Company.cs
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
namespace Domain.Concrete
{
    public partial class Repository
    {
        public List<ReportBalance> GetBalancesToUser(DateTime firsTime, DateTime lastTime, int companyid) =>
            ctx.ReportBalance.Where(rb => rb.Period >= firsTime && rb.Period <= lastTime && rb.CompanyId == companyid)
                                         .GroupBy(rb => rb.Period)
                                         .AsEnumerable()
                                         .Select(group => new ReportBalance
                                         {
                                             Period = group.Key,
                                             SaldoIn = group.Sum(x => x.SaldoIn),
                                             SaldoGet = group.Sum(x => x.SaldoGet),
                                             Amount = group.Sum(x => x.Amount),
                                             Paid = group.Sum(x => x.Paid),
                                             SaldoOf = group.Sum(x => x.SaldoOf),
                                             SaldoOut = group.Sum(x => x.SaldoOut),
                                         }).ToList();
Возвращать репозиторий может что угодно.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
15.05.2018, 15:07
Помогаю со студенческими работами здесь

Концепция БД
Здравствуйте. Есть такая мысль- собираюсь сделать Клиент/Серверную БД. Сами данные БД будут храниться в MySQL. А выводиться и...

Концепция контрола
Здравствуйте. Необходимо написать контрол, разделенный на 144 клетки. Для дальнейшей разработки удобнее было бы, чтобы каждая клетка была...

Концепция SEO
Может быть вопрос не правильный, но все же. В чем отличия продвижения товаров и услуг и продвижения сайта. Или же это одно и тоже?

Концепция разработки ПО
Пишу прогу, которая должна еще сохранять данные в БД,пока локальную, но в будущем планируется синхронизация с сервером где расположена...

Концепция сигналов и слотов
Часто, когда просматриваю проекты, написанные другими программистами, встречаю примерно такое: connect(server,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru