отображать данные из базы данных?
В секунду туда прилетает 5-50 записей и это делается постоянно.
Если делать select() у модели то это очень накладно, и чем дальше тем больше данных придется из БД копировать.
Есть какой-то хороший способ отображать записи из БД при этом постоянно обновляясь?
Можно notify слушать. [signal] void QSqlDriver::notification(const QString &name, QSqlDriver::NotificationSource source, const QVariant &payload) У QSqlDriver
не все БД драйвера поддерживают
Тут да, согласен. Работаю в основном с PostgreSQL, там работает. А вот лучше варианта из "прямых" не вспомнил.
ну и вопрос немного не о том автор спрашивает, как обновлять данные, он и сам знает без уведомления со стороны БД, что прилетают новые данные постоянно щас отвечу ему по этому поводу
while (model->canFetchMore()) model->fetchMore();
Перечитал, и стало интересно что за модель? QTableView сам сигналы от моделей слушает. Я правильно понимаю что тут вопрос как лучше модельку реализовать?
Ну возможно ему это и нужно. Только непонятно при чем тут тогда QTableView не совсем ясно.
про TableView можно было не читать. Автор просто развернутый вопрос задал. Это нормально. Вопрос про модель, но не реализацию, а что делать с select() который тянет всегда всю базу (на самом деле может оказать, что тоже не всю и тогда fetchMore всплывет сам собой, на fireBird я с этим сталкивался)
И бывает если мы читаем только вперёд выставить setForwardOnly в true, чтобы драйвера лишнего не кэшировали, в mssql сталкивался
ну в общем нюансы драйверов уже
Можно ещё юзать курсоры.
ну товарищ спрашивал как действовать со стороны Qt, а не со стороны СУБД а так да, можно
тут
Делал с помощью серверной программы. Клиент подключаясь к серверу, забирает N первые записи с бд. Сервер как раз общается с бд. N записей имеется ввиду с помощью limit. На клиенте модель организована с can fetch и подгружает новые записи при прокрутке таблицы. Напрямую с бд никто не работает, кроме сервера. Когда один или несколько клиентов вносят изменения, сервер изменяет данные в бд и оповещает всех клиентов новыми данными изменяя на лету отображение у клиентов
Обсуждают сегодня