Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 16.04.2019
Сообщений: 3

Реализация паттерна MVC с подключённой БД

29.09.2023, 09:10. Показов 1214. Ответов 1

Студворк — интернет-сервис помощи студентам
Решился в образовательных целях свделать программку, использующую БД PostgreSQL в качестве хранилища данных. Хочу применить паттерн Model-View-Controller. Для этого разделил соответствующие элементы каждый в свой файл, подключаю их как модули. Но столкнулся с проблемой, что мне либо в View-файле надо подключиться к БД (и принцип поломается, да к тому же придётся протягивать к встроенным функциям переменную подключения), либо при вызове внутренних функций необходимо постоянно открывать-закрывать подключение к БД.

Возникает 2 вопроса:
• Нормально ли разделять так значимые логические элементы? Как вообще правильно?
• Нормально ли, что будет постоянно происходить подключение-отключение к БД? Может есть более хитрый способ?

PS "встроенными функциями" я называю те, что находятся в других файлах. ex. модуль View вызывает функцию, лежащую в Controller, там уже вызываются функции из модуля Model, где уже лежит код взаимодействия с SQL
PPS для самых дотошных, я знаю, что в Python нет переменных, есть имена, но так проще изъясняться
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.09.2023, 09:10
Ответы с готовыми решениями:

Реализация паттерна MVC
Доброго времени суток. Допустим у меня есть класс Database в котором 2 метода: class Database { public OleDbConnection...

Реализация MVC паттерна в несложном desktop приложение на Java
Добрый вечер! Я новичок в Java и решил написать своё первое приложение, в котором будет использоваться MVC паттерн. Идея простая: есть...

Реализация паттерна Prototype в MVC через открытые члены
Всем доброго времени суток! Реализую приложение с родительской формой и несколькими дочерними. Для каждой дочерней формы применяется...

1
963 / 718 / 276
Регистрация: 10.12.2016
Сообщений: 1,764
29.09.2023, 12:12
я бы посоветовал посмотреть готовые реализации для PyQt
http://it.kgsu.ru/Python_Qt/oglav8.html
https://github.com/baoboa/pyqt... amples/sql
реализация Qt отличается от классической MVC
http://it.kgsu.ru/Qt/qt0099.html

но вообще в общем случае -
1-создается подключение в БД(курсор)
2-выполняется запрос
3-заполняется таблица по результатам запроса
4-таблица отображается во View(GUI)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.09.2023, 12:12
Помогаю со студенческими работами здесь

Интерактивное консольное приложение с использованием паттерна MVC
Требование: Разработайте специальный класс-контейнер, который будет хранить значе-ния целевой последовательности (вектора, списка и т.п.)...

Вывод модулей на страницы с использованием паттерна MVC
Пишу систему управления с использованием MVC паттерна, написал клсс маршрутизации который в зависимости от запрошенного пользователем...

Нужен совет по правильному использованию MVC - паттерна для составления блок схем
Есть вопрос: необходимо реализовать на основе шаблона MVC следующую систему отображения данных (выводиться будет в браузере в canvas). ...

Реализация паттерна Singleton
Добрый день. Необходимо реализовать класс Storage, объект которого будет единственным в программе. Для достижения данной цели было выбрано...

Реализация паттерна Стратегия
У меня задание, нужно реализовать паттерн Стратегия на примере моей программы, читал про сам паттерн, но не совсем понимаю, как реализовать...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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-код на мобильном. Вращайте камеру одним пальцем,. . .
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-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru