Russian Qt Forum
Июнь 15, 2024, 19:58 *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

Войти
 
  Начало   Форум  WIKI (Вики)FAQ Помощь Поиск Войти Регистрация  

Страниц: [1]   Вниз
  Печать  
Автор Тема: QSqlTableModel и скорость переобновления данных  (Прочитано 3365 раз)
aliks-os
Гость
« : Май 31, 2011, 16:19 »

Стандартно подключаюсь к MySQL, вывожу данные в QTableView.
Кол-во строк порядка 600 тыс.
Пользователь в гриде меняет любое значение, происходит сохранение
и далее пауза...происходит обновление данных. Как писано в мануале,
происходит обновление данных. Перепробовал различные стратегии редактирования,
но видно в любом случае происходит переподтягивание данных.

Подскажет ли кто, как можно эффективно решить данную проблему,
чтобы пользователю это не мешало работать.
Записан
alexman
Гость
« Ответ #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
Гость
« Ответ #2 : Май 31, 2011, 16:39 »

4. Не надо полность обновлять данные!

Вот в том то и дело! Как правильно избежать этого!
Записан
aliks-os
Гость
« Ответ #3 : Май 31, 2011, 17:24 »

Ну кажись победил...
Переопределил у модели setData и в нем использовал updateRowInTable. Ну а также у модели установил onManualUpdate
Записан
asvil
Гость
« Ответ #4 : Май 31, 2011, 17:25 »

Ах, воркароунды, воркароунды...
Записан
aliks-os
Гость
« Ответ #5 : Май 31, 2011, 17:32 »

Ах, воркароунды, воркароунды...

Яркий пример словоблудия
Записан
alexman
Гость
« Ответ #6 : Май 31, 2011, 17:57 »

Ах, воркароунды, воркароунды...
Это в чей огород? Объясни тогда как грамотнее реализовать?
Записан
asvil
Гость
« Ответ #7 : Май 31, 2011, 18:09 »

Свою модель написать, конечно.
Записан
Страниц: [1]   Вверх
  Печать  
 
Перейти в:  


Страница сгенерирована за 0.039 секунд. Запросов: 17.