Всем привет, как можно в QTableView через модель в реалтайм

отображать данные из базы данных?
В секунду туда прилетает 5-50 записей и это делается постоянно.
Если делать select() у модели то это очень накладно, и чем дальше тем больше данных придется из БД копировать.

Есть какой-то хороший способ отображать записи из БД при этом постоянно обновляясь?

14 ответов

22 просмотра

Можно notify слушать. [signal] void QSqlDriver::notification(const QString &name, QSqlDriver::NotificationSource source, const QVariant &payload) У QSqlDriver

Angry Subst
не все БД драйвера поддерживают

Тут да, согласен. Работаю в основном с PostgreSQL, там работает. А вот лучше варианта из "прямых" не вспомнил.

Повторев Владимир
Тут да, согласен. Работаю в основном с PostgreSQL,...

ну и вопрос немного не о том автор спрашивает, как обновлять данные, он и сам знает без уведомления со стороны БД, что прилетают новые данные постоянно щас отвечу ему по этому поводу

while (model->canFetchMore()) model->fetchMore();

Angry Subst
ну и вопрос немного не о том автор спрашивает, как...

Перечитал, и стало интересно что за модель? QTableView сам сигналы от моделей слушает. Я правильно понимаю что тут вопрос как лучше модельку реализовать?

Ну возможно ему это и нужно. Только непонятно при чем тут тогда QTableView не совсем ясно.

Повторев Владимир
Ну возможно ему это и нужно. Только непонятно при ...

про TableView можно было не читать. Автор просто развернутый вопрос задал. Это нормально. Вопрос про модель, но не реализацию, а что делать с select() который тянет всегда всю базу (на самом деле может оказать, что тоже не всю и тогда fetchMore всплывет сам собой, на fireBird я с этим сталкивался)

Angry Subst
про TableView можно было не читать. Автор просто р...

И бывает если мы читаем только вперёд выставить setForwardOnly в true, чтобы драйвера лишнего не кэшировали, в mssql сталкивался

Можно ещё юзать курсоры.

TheDoctor
Можно ещё юзать курсоры.

ну товарищ спрашивал как действовать со стороны Qt, а не со стороны СУБД а так да, можно

тут

Делал с помощью серверной программы. Клиент подключаясь к серверу, забирает N первые записи с бд. Сервер как раз общается с бд. N записей имеется ввиду с помощью limit. На клиенте модель организована с can fetch и подгружает новые записи при прокрутке таблицы. Напрямую с бд никто не работает, кроме сервера. Когда один или несколько клиентов вносят изменения, сервер изменяет данные в бд и оповещает всех клиентов новыми данными изменяя на лету отображение у клиентов

Похожие вопросы

Обсуждают сегодня

Ребята, всем привет. Подскажите, пожалуйста, можно ли как-то через бота понять, что этого бота добавили в группу\канал и выдали ему права администратора?
Artem Stormageddon
9
Это переведённый текст с английского. Я не говорю на русском, но могу использовать переводчик Телеграм. Приветствую! Я начинающий веб-разработчик и все еще учусь. В настояще...
𐩱𐩪𐩣𐩱𐩲𐩺𐩡
2
А не хотим ли мы развлечься? 😉 Но так чтобы с пользой для наших профессиональных навыков?? 👨‍🎓👩‍🎓 Предлагаю на октябрь запланировать тестовый запуск новой командной игры "Игр...
Andrii Kurdiumov
2
Привет всем! Почему этот код не срабатывает при добавлении или удалении пользователя из чата? bot.on('chat_member', async (ctx) => { console.log(ctx); }) bot.launch({allo...
Alexander
5
у кого сколько оперативы на базе данных ?
АДИЛЬБЕК
4
Через бот апи возможно получить ID стикерпака? Не ссылку.
Vexylon [АФК до 09.09]
5
Привет Хочу сделать аналог iCloud’а для своих проектов, чтобы пользовательская информация хранилась в облаке, была доступна во всех сервисах, её можно было подсасывать везде)...
Виталий
9
В тг можно спарсить всех кто пишет в группе? Если список участников скрыт
S
3
код Event::listen('cms.page.display', function (&$content, $slug, $page, $html) { if (is_object($content)) { dump($content); } else { dump($s...
Point 111
3
Доброе утро, мультиязычные сайты делал кто-нибудь? Какие подводные камни? Нужно чего нибудь допом ставить? Как поступить? В теории сделать две папки ru en и туда кидать страни...
Racoon Mitya
2
Карта сайта