Russian Qt Forum

Qt => Общие вопросы => Тема начата: qks1 от Август 01, 2013, 10:31



Название: Ищу советов по ускорению работы программы
Отправлено: qks1 от Август 01, 2013, 10:31
Ситуация такая: есть база данных с информацией о товарах, которыми торгует фирма (id, название, количество, цена, параметры и т.п.) - всего несколько десятков тысяч наименований. В приложении есть табвиджет с десятком вкладок, каждая из которых содержит QTableView/QSqlQueryModel, отображающие информацию из БД (не все товары, естественно, обычно не более полусотни строк). Работа ведётся одновременно в нескольких вкладках, список отображаемых строк постоянно меняется в зависимости от применённых фильтров. Так вот, если в одной из вкладок изменяется информация о товаре (цена ли изменяется, количество или что угодно ещё) - информацию о нём нужно обновить во всех вкладках. Как это сделать быстро?
Если тупо в каждой вкладке делать setQuery(model->lastQuery) - это слишком долго. Если учесть, что одномоментно меняется информация только в одной, максимум в двух строках - можно в каждой таблице пробежать по всем строкам и обновлять только те таблицы, где есть требуемая строка. Это быстрее, но всё равно слишком долго.
Вообще, как-то неразумно, на мой взгляд, из-за одной изменённой строки обновлять всю таблицу. Может, есть смысл использовать прокси-модель и обновлять данные вручную, методом setData, а не делать запрос к базе? Это должно быть быстро, но весьма ошибкоопасно, мне кажется... Может, кто-то подскажет другую идею?

Печаль в том, что под рукой есть подобный проект, написанный в эпоху динозавров неизвестно на чём, и там обновление выполняется практически мгновенно... Бен ай нид хелп?


Название: Re: Ищу советов по ускорению работы программы
Отправлено: dio от Август 02, 2013, 10:58
Для начала, сделайте обновление при переключении вкладки. 

Цитировать
Может, есть смысл использовать прокси-модель и обновлять данные вручную, методом setData, а не делать запрос к базе? Это должно быть быстро, но весьма ошибкоопасно, мне кажется..

У Вас многопользовательское приложение? Если да, то следует подумать над тем как организовать работу с одними данными несколькими пользователями одновременно (либо блокировать данные, либо проверять не было ли изменений).


Название: Re: Ищу советов по ускорению работы программы
Отправлено: panAlexey от Август 05, 2013, 10:52
А другой проект какую архитектуру имеет?
И что там со вьювами? На каких принцыпах построены?
ПС. Пора для sql таблиц делать свою вьювную систему.


Название: Re: Ищу советов по ускорению работы программы
Отправлено: voral от Август 08, 2013, 16:54
Не зная тонкостей проекта трудно предложить реально годное решение. Если честно я даже не сталкивался с такими задачами как я представил из вашего пояснения. Хотя наверное возможно. Попробую несколько раз ткнуть пальцем в небо.

1. Если набор данных, по сути, один и тот же то и завязать на один набор данных. А всю разницу: фильтры и сортировки надстраивать.
2. Если есть некий idшник/признак по которому можно соединить строки в разных таблицах - соединяем сигнал/слот. Далее в зависимости от информации - может просто подменяем отображаемое значение. Не дергая ни какие запросы. Может дергаем только по конкретной записи.
3. Внимательно оценить ситуацию - реально ли есть необходимость держать открытыми столько окон, не будет ли оптимальнее, например, объеденить какието
4. Какимто окнам просто передать сигналом что надо обновить данные. Далее по ситуации: либо при оактивировании окна обновляем данные, либо (при активировании окна) выводим запрос: "Данные изменилис. Обновить: да нет"