Юрий
ЮрийApril 11, 2017, 12:02 p.m.

Обновление модели по таймеру при изменении в БД

Qt

Как реализовать механизм обновления данных в QTableView при изменении в БД MySQL

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

5
Evgenii Legotckoi
  • April 11, 2017, 12:40 p.m.
  • The answer was marked as a solution.

Ну, если вопрос по реализации обновления от таймера, то по сигналу просто делайте select в модели данных. Если конечно используется какая-нибудь модель данных типа QSqlTableModel , QSqlRealtionalTableModel или модель наследованная от этих моделей.

В заголовочном файле добавьте объект QTimer, можно причём сохранить в стеке, а не в куче через оператор new .

QTimer m_timer;

А если учесть, что метод select() у модели данных QSqlTableModel является публичным слотом, то можно напрямую сигнал от таймера подключить к этому методу. Тогда с определённой периодичностью будут обновляться данные, если они изменялись.

Вот например обновление раз в минуту:

m_timer;
connect(&m_timer, &QTimer::timeout, model, &QSqlTableModel::select);
m_timer.start(60 * 1000);

Модель данных должна быть установлена в QTableView . Чтобы узнать об изменениях в базе данных, нужно будет сделать выборку ( select() ). Сама БД никак не сообщит об этом.

    Юрий
    • April 11, 2017, 1:28 p.m.

    Так я и сделал, но мне надо при изменении данных в таблице БД .

      Evgenii Legotckoi
      • April 11, 2017, 1:39 p.m.

      Когда происходит изменение данных в таблице БД? При каких действиях. Они же не на пустом месте происходят? При изменении данных сторонними средствами? Сторонней программой? Или вашей же программой? Поподробнее никак нельзя объяснить проблему? Серебряной пули не бывает.

        Юрий
        • April 11, 2017, 1:48 p.m.

        А если проверять значения с помощью

        SELECT   `UPDATE_TIME`
         FROM  INFORMATION_SCHEMA.PARTITIONS
         WHERE   TABLE_NAME   = 'table'
        и сравнивать с ранее сохраненным значением?
          Evgenii Legotckoi
          • April 11, 2017, 2:05 p.m.

          Да. Это может сработать. Во всяком случае нагрузка может уменьшиться. Вместо того, чтобы тащить всю таблицу через select будете делать более экономичный запрос, но опять же по таймеру. Вообще у QSqlDriver есть возможность подписки на уведомления от базы данных. Метод subscribeToNotification , но вот тут уже проблема имеется в том, что MySQL не имеет механизма notify , то есть подписаться на уведомления от базы данных просто так не получится, вообще информации по MySQL на эту тему практически нет. А вот с PostgreSQL здесь в разы лучше ситуация. У него имеются уведомления, на которые можно подписаться, самые простые NOTIFY, LISTEN, UNLISTEN . Можно вроде как и на отдельные таблицы подписываться. Так что в случае с PostgreSQL это проще реализовать. Сама база данных будет этому способствовать. В случае же с MySQL - это таймеры и прочие костыли. Так что, если есть возможность сменить БД , то подумайте над этим.

            Comments

            Only authorized users can post comments.
            Please, Log in or Sign up
            Lz

            C ++ - Test 004. Pointers, Arrays and Loops

            • Result:70points,
            • Rating points1
            РК

            Qt - Test 001. Signals and slots

            • Result:84points,
            • Rating points4
            Last comments
            k
            kmssrFeb. 9, 2024, 2:43 a.m.
            Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
            Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
            EVA
            EVADec. 25, 2023, 6:30 p.m.
            Boost - static linking in CMake project under Windows Ошибка LNK1104 часто возникает, когда компоновщик не может найти или открыть файл библиотеки. В вашем случае, это файл libboost_locale-vc142-mt-gd-x64-1_74.lib из библиотеки Boost для C+…
            J
            JonnyJoDec. 25, 2023, 4:38 p.m.
            Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
            G
            GvozdikDec. 19, 2023, 5:01 a.m.
            Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
            Now discuss on the forum
            BlinCT
            BlinCTJune 25, 2024, 8 a.m.
            Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
            Evgenii Legotckoi
            Evgenii LegotckoiJune 24, 2024, 10:11 p.m.
            добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
            BlinCT
            BlinCTMay 5, 2024, 12:46 p.m.
            Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
            Evgenii Legotckoi
            Evgenii LegotckoiMay 2, 2024, 9:07 p.m.
            Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.
            IscanderChe
            IscanderCheApril 30, 2024, 11:22 a.m.
            Во Flask рендер шаблона не передаётся в браузер Доброе утро! Имеется вот такой шаблон: <!doctype html><html> <head> <title>{{ title }}</title> <link rel="stylesheet" href="{{ url_…

            Follow us in social networks