Юрий17 серпня 2019 р. 12:54
Как правильно отслеживать актуальность базы данных
Добрый вечер.
Подскажите как правильно синхронизировать структуру БД? С другим рабочем местом.
БД MySQL.
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 11 листопада 2024 р. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 01:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 01:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 11:51
Evgenii Legotckoi31 жовтня 2024 р. 14:37
Читалка файлів 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 аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi24 червня 2024 р. 15:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 06:04
NSProject04 червня 2022 р. 03:49
IscanderChe31 жовтня 2024 р. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Не очень понятен вопрос. База одна или их несколько?
База одна.
Как отслеживать структуру в самой БД и той которая в приложении.
Обратился я к таблице, а ее нет в данной версии БД и приложение упало.
Сейчас я использую MySQL Workbench, создаю EER model и потом синхронизирую структуру БД где мне нужно, но вот хотелось бы автоматом проверять совместимость БД с приложением.
Надеюсь правильно изложил мысль.
Т.е. таблицы в БД к которым обращается приложение могут отсутсвовать?
Все верно.
Программно можно проверить существование таблицы, получить список таблиц БД, получить список полей конкретной таблицы и т.д. Это все на совести программиста и если структура БД может меняться, то такие проверки необходимо делать до обращения к таблицам, чтоб приложение не падало.
Список таблиц в Qt: QSqlDatabase::tables(...)
У нас в проекте создана таблица, в которой вносятся версии базы данных, в зависимости от версии используется соответствующая логика.
В случае с Django, например, имеется таблица миграций, и каждая запись соответствует миграционному файлу. Автоматически делается проверка на структуру базы данных, и если есть изменения, то нужно применить новые миграции.
Ещё как вариант, то дополнительно прикрутить REST API к серверу базы данных и отдавать данные в виде JSON структур. Их будет проще распрасить, чтобы приложение не падало.
думаю что-то подобное)))
Тут только получим сами таблицы, а колонки и тип данных. Таблицы не так часто меняются, а вот тип данных и колонки очень даже часто.
Вам нужно вести версионирование базы данных и в зависимости от версии использовать соответсвующую логику. Иначе никак. У нас на проекте тоже имеется проблема с версионированием в базе данных. Просто создали таблицу, которая содержит версию, и в зависимости от версии либо конвертируем поля, либо ничего не делаем, то есть игнорируем логику, либо делаем ещё что-то, что требуется.
То есть однозначно нужна таблица с версией базы данных.
Естественно, что это хорошо работает в том случае, если приложение последней версии открывает базу данных старшей версии или той же самой.
Старое приложение откроет новую базу данных скорее всего с ошибками. Либо после проверки предлагать обновление и ничего не делать.
У нас реализовано так что при запуске программа проверяет версию БД (естетсвенно она хранится в таблице) если версия БД младше то выполняется обновление бд. На каждую новую версию если изменяется структура БД создается sql файл со скриптами которые и зменяют БД 20190806_update_tanks.sql например. И программа последовательно выполняет скрипты для модификации БД и только потом запускается.
Если Вы разрабатываете какую-то универсальную утилиту, которая вообще не привязана к логике, тогда как вариант:
1. Получить список таблиц через QSqlDatabase::tables
2. Для каждой таблицы получить список столбцов, например так:
Но вариант Евгения правильнее и логичнее если ПО делается под конкретную БД.
В принципе я так и делаю, у меня есть таблица с номером текущей версии БД.
При запуске приложения происходит проверка версии БД поддерживаемой приложением.
Потом получаю данные в Json формате с сайта и проверяю на новые версии.
Если вышла новая версия, предлагаю обновиться и запускаю стандартный интерфейс (QtIFW) обновления из репозитория.
Спасибо, расказали подробно.