|
|
|
.NET 4.x Какой наиболее правильный паттерн при работе с SQLite08.11.2015, 01:00. Показов 2340. Ответов 34
Метки нет (Все метки)
Что есть:
Entity Framework - набор классов для работы с базой данных WPF - забинденные Listview ... DataGrid ... Combobox к свойствам контекста (ObservableCollection) Много форм, где контекст изменяется Что надо: подсказать наиболее рациональный паттерн. Изменяя контекст - изменялись бы (обновлялись) все контролы на всех формах автоматом (может по событиям?) Т.е. в одной форме происходит отображение одной главной таблицы, во второй форме создаётся новый объект. Добавлено через 1 минуту На данный момент реализовал всё через костыльные события и, что ещё хуже для обновления контролов обнуляю ссылку на коллекцию которая была привязана, потом подключаю её ещё раз - так обновляется.
0
|
|
| 08.11.2015, 01:00 | |
|
Ответы с готовыми решениями:
34
Правильный стиль при работе со строками Как сделать наиболее точные замеры производительности SQLite при вставке данных |
| 09.11.2015, 16:00 | |
|
Попробуйте, предварительно перечитав доки. Начинайте с простого.
0
|
|
|
|
||
| 09.11.2015, 20:46 [ТС] | ||
|
Оно то да. Только вот посоветовали отделить Entity. Создать репозиторий, для того чтобы не воздействовать на контекст и на базу напрямую. Потом создать уже отдельную модель, а потом уже mvvm.
Добавлено через 4 минуты
0
|
||
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
|
| 10.11.2015, 00:02 | |
|
skilllab, Что значит правильно?) Для каждой задачи существуют свои методы их решения. А если ты хочешь попрактиковаться, то сделай обычную 3х уровневую архитекту своего приложения (UI слой, слой доменной модели, слой БД). Естественно, репозиторий, для предоставления абстракции для хранения сущностей (а не для воздействия на БД. Репозиторий, не более, чем просто коллекция. Просто абстракция, где хранятся данные, дабы не привязываться к конкретной реализации). В доменном слое у тебя доменные модели (POCO-классы обычные), какие то сервисы, которые поставляют тебе объекты в слой приложения. Естественно, все эти сервисы используются через DI, дабы уменьшить связанность твоего приложения и программировать на уровне интерфейсов, а не конкретных реализаций. Ну и можно DTO реализовать, если ты клиент-серверное что то пилить собрался.
P.S. А еще я тебе советую это (прям сам реализуй по примерам, а не слизывай с исходников, пытайся вникнуть и всё такое): http://www.codeproject.com/Art... n-Practice Может мало поймёшь, зато английский будет повод подтянуть)
1
|
|
|
|
||||||||||
| 10.11.2015, 07:46 [ТС] | ||||||||||
|
ты пишешь, что репозиторий для хранения. Я сам понимаю, что нужно нечто, что будет внутри себя обрабатывать данные, и уже после обновлять их в базе. Сам Repository:
------------------------ на то его и придумали.Решения с "упростить в связи с тем что делаешь всё локально и для себя" не предлагать. Я уже "так" сделал, теперь хочу познать науку. ![]() Добавлено через 9 минут Добавлено: хотяя...хранение представления базы данных в коде, может занять пипец какой объём оперативки. Так что может подход и верный.
0
|
||||||||||
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
||
| 10.11.2015, 08:43 | ||
|
skilllab,
0
|
||
|
|
|||
| 10.11.2015, 09:44 [ТС] | |||
|
ибо Может я радикально что-то не понимаю. Накатаю вечером проект, выложу.Topotun, сможете просто подсказать, помочь, в правильном ли я направлении всё делаю?
0
|
|||
|
Master of Orion
|
|
| 10.11.2015, 10:49 | |
|
EF вполне себе репозиторий сам по себе. Он собственно для того и был создан, чтобы не писать репозиторий-бойлерплейт, а просто сказать "сделай мне репозиторий для такой-то базы".
0
|
|
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
||
| 10.11.2015, 13:14 | ||
|
Psilon, Создан он был для этого, но видимо не сложилось. И всегда (ну, часто очень) создают абстракцию поверх абстракции из-за проблем совместимости разных провайдеров данных. Сценарий, который ты выполняешь, используя один провайдер, может некорректно работать на другом. И типы данных (не все типы данных из EF поддерживаются базами данных). Производительность (само собой). А еще проблема в IQueryable, который предоставляет универсальный интефейс, который позволяет писать огромное количество разнообразных запросов. Всё бы хорошо, но не все разработчики конкретных LINQ провайдеров их поддерживают, поэтому, создав абстракцию (репозиторий) поверх EF, можно создать репозиторий со своим интерфейсом, с помощью которого можно будет как то органичить запросы
skilllab, Добавлено через 22 минуты
Ответь сначала (для себя, а не мне) на эти вопросы сам (без гугла). А потом, когда поймёшь, что у тебя очень много пробелов, тогда открывай гугл и читай, очень много читай. Я не вижу смысла отвечать на такие вещи, когда даже в базовых вещах трудности, потому что так можно днями напролёт переписываться и на пустом месте спорить. P.S. Конкретный смысл репозитория - скрывать способ доступа к данным от остальных слоёв ПО. Репозиторий, это всё такие хранилище. Хранит репозиторий Entity (сущности). В идеале, поверх репозитория пишут сервисный слой, который Entity преобразовывает (принимают и отдают) в DTO объекты и эти объекты уже передаёт уже другим слоям ПО. Так, что бы Entity не была видна за пределами этих сервисов.
1
|
||
|
Master of Orion
|
|
| 10.11.2015, 14:58 | |
|
Topotun,
1) EF поддерживает многопровайдерность 2) Всегда можно накрутить слой абстракции поверх, с которым будет удобнее работать. Главное, чтобы этих слоев не стало слишком много.
0
|
|
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
|
| 10.11.2015, 15:09 | |
|
Psilon, Я разве написал, что EF не поддерживает многопровайдерность?) Поддерживает. Только проблема то в другом. Проблема в том, что на практике, разные провайдеры могут вести себя (и не только могут, но и ведут) по разному.
Тут вопрос не удобства, а необходимости
0
|
|
|
Master of Orion
|
|
| 10.11.2015, 19:05 | |
|
Topotun, так-то да. Я ж говорю, всегда можно накрутить слой абстракции поверх, и почти вседа он будет удобнее нижележащего. На этом вообще все программирование построено. Вопрос только в пользе от такого слоя. Ибо она бывает меньше, чем удобство от неё. Я помню пробовал в свое время прикрутить свой слой работы с AD поверх стандартного. В результате после кучи рефакторинга практически все выкинулось. Осталась только пара методов расширений, вроде транзакционного изменения нескольких свойство в сущности с rollback'ом в случае неудачи. Короче, пользы от этого слоя было мало, и я от него избавился. Просто такой вот пример из личного опыта.
0
|
|
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
|
| 10.11.2015, 19:34 | |
|
Psilon, Спасибо за пример из личного опыта (реально спасибо, без сарказма). А по поводу всего остального, меня просто смутило, что ты постоянно говоришь про "удобство". У меня просто "удобство" ассоциируется просто с плюшками, которые не особо то и нужны. Но абстракция, поверх абстракции иногда бывает жизненно необходимо) А ты говоришь про "удобство". Может, конечно, это лично мои загоны, но когда ты работаешь в команде из 5ти разработчиков, то про удобство говорить слишком эгоистично, так как то, что тебе удобно, может быть другим ребятам не удобно=)
Ну а суть я уловил. Разными словами об одном и том же говорили
0
|
|
|
|
|||||||||
| 10.11.2015, 19:49 [ТС] | |||||||||
|
Добавлено через 2 минуты Добавлено через 2 минуты ![]() Пожалуй да - "на разных языках говорим"
0
|
|||||||||
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
|||
| 10.11.2015, 20:00 | |||
|
skilllab, Вопросы были для того, чтоб ты сам себе ответил на них) Я то ответы знаю)
Я тебе еще раз повторяю, что то, что ты прислал, это не реализация, а всего лишь интерфейсная часть. Попробуй реализовать
P.S. Ответ может каким то грубым показаться, но ты же понимаешь, что обидеть я тебя не хотел ничем, да?) Вот и хорошо) Мне просто хочется, чтоб ты лично сам (с минимальной поддержкой) победил эту задачу и сам совершил для себя открытие)
0
|
|||
|
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
|
||||||||||||||||
| 10.11.2015, 20:04 | ||||||||||||||||
|
Кто-то из присутствующих когда-нибудь использовал репозиторий?
По мне это крайне неоднозначная тема
0
|
||||||||||||||||
|
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
|
||||||
| 10.11.2015, 20:12 | ||||||
|
И кстати если делать - потом по всей программе гонять кучу этих репозиторев?
0
|
||||||
|
95 / 54 / 10
Регистрация: 16.09.2012
Сообщений: 207
|
|||||
| 10.11.2015, 20:19 | |||||
|
m0nax,
Добавлено через 53 секунды m0nax, Если ты гоняешь по всей программе репозиторий, то это уже проблема в архитектуре всё таки) Я вот тоже не знаю, зачем нужен такой репозиторий, если потом по всей программе его гонять) Скорее в проектировании приложения проблема, а ты паттерн обижаешь)
0
|
|||||
|
1274 / 975 / 113
Регистрация: 12.01.2010
Сообщений: 1,971
|
||
| 10.11.2015, 20:25 | ||
|
repo.GetStudents().Where(....).Take(..). Order(By..
0
|
||
| 10.11.2015, 20:25 | |
|
Помогаю со студенческими работами здесь
20
Обработка событий при работе с sqlite Правильный синтаксис при работе с DBF VISUAL fox pro Порекомендуйте правильный паттерн Какая программа наиболее удобная при работе с Java Какой тип данных правильный при определении времени выполнения? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip
На первой гифке отладочные линии отключены, а на второй включены:. . .
|
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога
Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|