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

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

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

14 ответов

24 просмотра

Можно 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 и подгружает новые записи при прокрутке таблицы. Напрямую с бд никто не работает, кроме сервера. Когда один или несколько клиентов вносят изменения, сервер изменяет данные в бд и оповещает всех клиентов новыми данными изменяя на лету отображение у клиентов

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

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

Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Ребят, подскажите, пожалуйста, почему в префиксе к ассетам, которые генерируются через фильтр | theme в шаблоне, стал вдруг появляться index.php? Вот так выглядит ссылка на а...
Виталий
1
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Блин, ребята, сори за тупые вопросы. А можно ли как-то открыть вебапку по нажатию на кнопку в меню(которое появляется слева, команды)?
Artem Stormageddon
3
а плаксы из-под питона умеют только в комфортных условиях что-то выдавить из себя?)
Lencore
9
Но, может, есть уже проверенная? Наши требования такие: 1. Сообщения должны приходить из Инста в CRM оду 2. Должна быть возможность подключить несколько экаунтов Инстаграм. Р...
Alexander Sharoiko MSE / Александр Шаройко
13
Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
Коллеги, может знает кто, можно ли цвет бейджа счётчика в BackendMenu менять без бубнов?
Alex Blaze
3
Карта сайта