Russian Qt Forum
Ноябрь 23, 2024, 22:28
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Model-View (MV)
>
QSqlTableModel и скорость переобновления данных
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: QSqlTableModel и скорость переобновления данных (Прочитано 3424 раз)
aliks-os
Гость
QSqlTableModel и скорость переобновления данных
«
:
Май 31, 2011, 16:19 »
Стандартно подключаюсь к MySQL, вывожу данные в QTableView.
Кол-во строк порядка 600 тыс.
Пользователь в гриде меняет любое значение, происходит сохранение
и далее пауза...происходит обновление данных. Как писано в мануале,
происходит обновление данных. Перепробовал различные стратегии редактирования,
но видно в любом случае происходит переподтягивание данных.
Подскажет ли кто, как можно эффективно решить данную проблему,
чтобы пользователю это не мешало работать.
Записан
alexman
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #1 :
Май 31, 2011, 16:32 »
Делал подобное!
1. Можно завести кеш.
2. Переопределить метод bool setData ( const QModelIndex & index, const QVariant & value, int role = Qt::EditRole ) [virtual]: заносить данные и в БД, и в кеш.
3. Переопределить метод QVariant data ( const QModelIndex & index, int role = Qt::DisplayRole ) const [pure virtual]: если надо то возвращаем данные из кеша.
4. Не надо полность обновлять данные!
Записан
aliks-os
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #2 :
Май 31, 2011, 16:39 »
Цитата: alexman от Май 31, 2011, 16:32
4. Не надо полность обновлять данные!
Вот в том то и дело! Как правильно избежать этого!
Записан
aliks-os
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #3 :
Май 31, 2011, 17:24 »
Ну кажись победил...
Переопределил у модели setData и в нем использовал updateRowInTable. Ну а также у модели установил onManualUpdate
Записан
asvil
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #4 :
Май 31, 2011, 17:25 »
Ах, воркароунды, воркароунды...
Записан
aliks-os
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #5 :
Май 31, 2011, 17:32 »
Цитата: Филоненко Михаил от Май 31, 2011, 17:25
Ах, воркароунды, воркароунды...
Яркий пример словоблудия
Записан
alexman
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #6 :
Май 31, 2011, 17:57 »
Цитата: Филоненко Михаил от Май 31, 2011, 17:25
Ах, воркароунды, воркароунды...
Это в чей огород? Объясни тогда как грамотнее реализовать?
Записан
asvil
Гость
Re: QSqlTableModel и скорость переобновления данных
«
Ответ #7 :
Май 31, 2011, 18:09 »
Свою модель написать, конечно.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...