Юрий17 серпня 2019 р. 12:54
Как правильно отслеживать актуальность базы данных
Добрый вечер.
Подскажите как правильно синхронизировать структуру БД? С другим рабочем местом.
БД MySQL.
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
sf
- sdfsdfkp fgskpgokspdog
- 14 жовтня 2024 р. 15:09
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:90бали,
- Рейтинг балів8
МВ
- Максим Васильев
- 02 жовтня 2024 р. 04:14
Qt - Тест 001. Сигналы и слоты
- Результат:68бали,
- Рейтинг балів-1
ЛС
- Лев Семенов
- 30 вересня 2024 р. 11:04
C++ - Тест 001. Первая программа и типы данных
- Результат:53бали,
- Рейтинг балів-4
Останні коментарі
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 07:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко05 лютого 2024 р. 01:50
Тепер обговоріть на форумі
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь Максимов03 жовтня 2024 р. 04:05
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
Кирилл Гусарев27 вересня 2024 р. 09:09
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
Не очень понятен вопрос. База одна или их несколько?
База одна.
Как отслеживать структуру в самой БД и той которая в приложении.
Обратился я к таблице, а ее нет в данной версии БД и приложение упало.
Сейчас я использую MySQL Workbench, создаю EER model и потом синхронизирую структуру БД где мне нужно, но вот хотелось бы автоматом проверять совместимость БД с приложением.
Надеюсь правильно изложил мысль.
Т.е. таблицы в БД к которым обращается приложение могут отсутсвовать?
Все верно.
Программно можно проверить существование таблицы, получить список таблиц БД, получить список полей конкретной таблицы и т.д. Это все на совести программиста и если структура БД может меняться, то такие проверки необходимо делать до обращения к таблицам, чтоб приложение не падало.
Список таблиц в Qt: QSqlDatabase::tables(...)
У нас в проекте создана таблица, в которой вносятся версии базы данных, в зависимости от версии используется соответствующая логика.
В случае с Django, например, имеется таблица миграций, и каждая запись соответствует миграционному файлу. Автоматически делается проверка на структуру базы данных, и если есть изменения, то нужно применить новые миграции.
Ещё как вариант, то дополнительно прикрутить REST API к серверу базы данных и отдавать данные в виде JSON структур. Их будет проще распрасить, чтобы приложение не падало.
думаю что-то подобное)))
Тут только получим сами таблицы, а колонки и тип данных. Таблицы не так часто меняются, а вот тип данных и колонки очень даже часто.
Вам нужно вести версионирование базы данных и в зависимости от версии использовать соответсвующую логику. Иначе никак. У нас на проекте тоже имеется проблема с версионированием в базе данных. Просто создали таблицу, которая содержит версию, и в зависимости от версии либо конвертируем поля, либо ничего не делаем, то есть игнорируем логику, либо делаем ещё что-то, что требуется.
То есть однозначно нужна таблица с версией базы данных.
Естественно, что это хорошо работает в том случае, если приложение последней версии открывает базу данных старшей версии или той же самой.
Старое приложение откроет новую базу данных скорее всего с ошибками. Либо после проверки предлагать обновление и ничего не делать.
У нас реализовано так что при запуске программа проверяет версию БД (естетсвенно она хранится в таблице) если версия БД младше то выполняется обновление бд. На каждую новую версию если изменяется структура БД создается sql файл со скриптами которые и зменяют БД 20190806_update_tanks.sql например. И программа последовательно выполняет скрипты для модификации БД и только потом запускается.
Если Вы разрабатываете какую-то универсальную утилиту, которая вообще не привязана к логике, тогда как вариант:
1. Получить список таблиц через QSqlDatabase::tables
2. Для каждой таблицы получить список столбцов, например так:
Но вариант Евгения правильнее и логичнее если ПО делается под конкретную БД.
В принципе я так и делаю, у меня есть таблица с номером текущей версии БД.
При запуске приложения происходит проверка версии БД поддерживаемой приложением.
Потом получаю данные в Json формате с сайта и проверяю на новые версии.
Если вышла новая версия, предлагаю обновиться и запускаю стандартный интерфейс (QtIFW) обновления из репозитория.
Спасибо, расказали подробно.