|
|
|
Создание модели данных или нет24.05.2018, 11:43. Показов 2936. Ответов 23
Метки нет (Все метки)
Допустим есть довольно сложная программа работающая с десятками таблицами из базы данных. Вот она создана с помощью встроенных конструкторов - путем добавления DataSet (пример на скрине) в виде файла xsd. И запросы и хранимые процедуры обрабатываюся там же в конструкторах. И в этом приложении нет отдельной модели данных в виде библиотеки dll. Вот такой подход к создание сложного приложения какой на ваш взгляд? Или все таки нужно создать модель данных без встроенных конструкторов?
0
|
|
| 24.05.2018, 11:43 | |
|
Ответы с готовыми решениями:
23
Создание библиотеки классов модели данных сущностей ADO.NET Создание отчета. CrystalReport или нет?? Создание базы данных на лету, создание и заполнение таблиц в базе DB (Paradox? или..). |
|
|
|
| 24.05.2018, 11:45 [ТС] | |
|
Просто интересно ваше мнение.
0
|
|
|
14303 / 9388 / 1354
Регистрация: 21.01.2016
Сообщений: 35,398
|
|
| 24.05.2018, 11:48 | |
|
aleksskay4, правильно было бы наделать моделей под каждую таблицу и отдельные виды запросов и положить их в отдельную сборку, которую могут другие части приложения переиспользовать (потенциально).
И под моделями я понимаю не DataSet-ы, а нормальные классы.
0
|
|
|
|
|
| 24.05.2018, 11:52 [ТС] | |
|
На примере можно показать?
0
|
|
|
14303 / 9388 / 1354
Регистрация: 21.01.2016
Сообщений: 35,398
|
|
| 24.05.2018, 11:57 | |
|
aleksskay4, я не уверен, что тут пример нужен. Классы создавать же умеете? Сборки? Вот и всё)
Классы должны представлять отражения таблиц. Так же могут быть классы-DTO, которые представляют результаты запросов (какие-то подмножества полей таблицы). Вот и вся магия.
0
|
|
|
|
|||||||||||
| 24.05.2018, 12:15 [ТС] | |||||||||||
|
Вот когда я создавал приложение там была таблица со столбцами id, question, first, second, third, forth, right я для него создал такой класс:
0
|
|||||||||||
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
|
| 24.05.2018, 12:15 | |
|
aleksskay4, ответ очень даже простой в этом случае. Модель создавать НУЖНО, даже если это не самая сложная программа. Это даст Вам много вкусняшек, из них можно выделить:
1. Создание нового объекта в памяти проще и быстрее, чем в СУБД, к тому же таблицы не портятся моментами создания записей и (потенциально) не будет проблем с автоинкрементами. 2. При сохранении объекта - это будет единовременная операция, и в случае многопользовательского режима можно установить блокировку через транзакцию. Особенно удобно при построении деревьев с их структурой parent-child. 3. При удалении объекта без сохранения - снова же не нужно дергать сиквел (а часто пользователи такими вещами пользуются, создали объект, а потом - не, не хочу, хочу другой - и отменили без сохранения). 4. Отделяете хранилище данных от Ваших форм, можно менять формы на ходу, не задумываясь о состоянии данных внутри, а работать с байндингами динамически. 5. Модель данных, при правильном проектировании не зависит от типов используемых СУБД, достаточно прописать различные реализации интерфейса для работы с разными СУБД. 6. Возможность менять даже технологию (WPF/WinForms) - а модель останется та же. Да и еще можно с десяток-другой вкусняшек написать. Это только то, что сразу в голову пришло. И да, модель - это не набор датасетов, а набор классов, в которых могут содержаться и датасеты тоже.
1
|
|
|
14303 / 9388 / 1354
Регистрация: 21.01.2016
Сообщений: 35,398
|
|
| 24.05.2018, 13:03 | |
|
aleksskay4, ваш пример страшно кривой. Это не модель - это какой-то класс-самозагружатор. Вариация на тему Active Record.
Под моделями данных понимаются обычные POCO (Plain Old CLR Object). Т.е. классы со свойствами без всякого (или с минимальным) поведения. Т.е. просто мешок с данными и всё. По такому классу не должно быть видно откуда в него данные попали, из базы или ещё откуда. Такой класс можно вообще везде переиспользовать: в консоли, в вебе, ещё где, в связке с СУБД MySQL или из MongoDB. Ваш же прибит гвоздями к OleDbConnection. Это уже не модель. Это уже некий сервис-мутант.
2
|
|
|
|
||||||
| 24.05.2018, 13:39 [ТС] | ||||||
0
|
||||||
|
14303 / 9388 / 1354
Регистрация: 21.01.2016
Сообщений: 35,398
|
||
| 24.05.2018, 13:42 | ||
|
aleksskay4, да, такой. Просто набор свойств.
0
|
||
|
|
|||||||
| 24.05.2018, 14:47 [ТС] | |||||||
0
|
|||||||
|
14303 / 9388 / 1354
Регистрация: 21.01.2016
Сообщений: 35,398
|
|
| 24.05.2018, 17:02 | |
|
aleksskay4, ну типа. Вы можете это сделать вручную, можете воспользоваться такими классными штуками как
PetaPoco и Dapper или вообще "взрослыми" ORM типа LINQtoDB и Entity Framework.
0
|
|
|
|
|||||||
| 25.05.2018, 16:22 [ТС] | |||||||
|
Когда я писал что-то вроде мессенджер я создал такой класс ? Она не подходит под модель? И как такой способ создание приложений(ваша оценка такому способу) ?
0
|
|||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,233
|
||
| 25.05.2018, 16:43 | ||
|
aleksskay4, вам ведь уже сказали, что модели, в общем случае, отображаются на таблицы. И это просто POCO, они не должны иметь способность сами себя загружать из бд. За загрузку данных извне отвечает абстрактный слой - репозиторий. Модель ни от чего не зависит, на то она и модель. Если вы смените используемую СУБД, то это никак не должно затрагивать модель. От этого и исходите.
2
|
||
|
|
||||||||||||||||
| 25.05.2018, 17:44 [ТС] | ||||||||||||||||
|
В плане репозитария наверно имеются в ввиду так:
0
|
||||||||||||||||
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,233
|
|
| 25.05.2018, 19:03 | |
|
aleksskay4, уже лучше. Но у вас в одном репо по сути две штуки - для кресел и для дверей.
Читали про interface segregation principle?
0
|
|
|
|
|
| 25.05.2018, 21:58 [ТС] | |
|
IamRain, А что нужно сделать?
0
|
|
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,233
|
|
| 25.05.2018, 22:02 | |
|
На каждую сущность отдельный репозиторий.
Обычно создают интерфейс для одной сущности и одну дефолтную реализацию.
0
|
|
|
|
|
| 25.05.2018, 22:10 [ТС] | |
|
0
|
|
|
4694 / 2702 / 734
Регистрация: 02.08.2011
Сообщений: 7,233
|
|
| 25.05.2018, 22:13 | |
|
Да, вот здесь есть мат.часть.
1
|
|
| 25.05.2018, 22:13 | |
|
Помогаю со студенческими работами здесь
20
Включать или нет базу данных в проект? Проверка занят или нет ник в базе данных Создание модели базы данных Динамическое создание модели данных Создание инфологической модели базы данных Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
[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-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|