Russian Qt Forum
Май 18, 2012, 19:10
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Пользовательский интерфейс (GUI)
(Модератор:
Sergeich
) >
Вопросы по QTableView
Страниц: [
1
]
2
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Вопросы по QTableView (Прочитано 1809 раз)
PavelVX
Самовар
Offline
Сообщений: 154
Вопросы по QTableView
«
:
Июль 20, 2011, 09:44 »
Добрый день всем!
1. В QTableView можно показать, скрыть колонки. А как мне просто поменять местами колонки? У меня с базы приходит все в определенном порядке, а в разных формах показывать надо по разному.
2. Сортировки: tableView->setSortingEnabled(true); (QSqlQueryModel)
2а. появились треугольнички, но если на них нажимать, то порядок сортировки не меняется.
2б. Можно ли как-то самому для конкретных колонок указывать по какому столбцу их сортировать?
«
Последнее редактирование: Январь 10, 2012, 10:26 от Пантер
»
Записан
Пантер
Administrator
Джедай : наставник для всех
Online
Сообщений: 4122
Жаждущий знаний
Re: Вопросы по QTableView
«
Ответ #1 :
Июль 20, 2011, 09:47 »
Тебе нужна QSortFilterProxyModel.
Записан
1. Qt - Qt Development Frameworks; QT - QuickTime
2. Не используйте в исходниках символы кириллицы!!!
3. Пользуйтесь тегом code при оформлении сообщений.
С уважением.
Пантер.
Kolobok
Бывалый
Online
Сообщений: 480
Re: Вопросы по QTableView
«
Ответ #2 :
Июль 20, 2011, 09:56 »
1. QTableView::horizontalHeader()::moveSection ( int from, int to )
Записан
Странник
Крякер
Offline
Сообщений: 310
Re: Вопросы по QTableView
«
Ответ #3 :
Июль 20, 2011, 13:05 »
2б. QTableView::sortByColumn(int column, Qt::SortOrder order).
Цитата: Пантер от Июль 20, 2011, 09:47
Тебе нужна QSortFilterProxyModel.
на небольших объемах работает неплохо, на выборках побольше тормозит нещадно. возможно, придется реализовывать
sort()
для модели самостоятельно.
меня еще интересует, как разрешить пользователю менять порядок столбцов drag-n-drop'ом. установка
tableView->horizontalHeader()->setMovable(true)
не помогает, есть еще что-то?
«
Последнее редактирование: Июль 20, 2011, 13:07 от Странник
»
Записан
Авварон
Джедай : наставник для всех
Offline
Сообщений: 1830
Re: Вопросы по QTableView
«
Ответ #4 :
Июль 20, 2011, 13:52 »
Почему у меня прокся с 19000 строк не тормозила?
Записан
Странник
Крякер
Offline
Сообщений: 310
Re: Вопросы по QTableView
«
Ответ #5 :
Июль 20, 2011, 14:02 »
Цитата: Авварон от Июль 20, 2011, 13:52
Почему у меня прокся с 19000 строк не тормозила?
интересно. у меня бобик дох на сортировке по строковому столбцу уже при ~5000 записей, даже на шустрой машинке. пойду эксперементировать.
Записан
Авварон
Джедай : наставник для всех
Offline
Сообщений: 1830
Re: Вопросы по QTableView
«
Ответ #6 :
Июль 20, 2011, 18:49 »
ну я 1 колонку фильтровал через startsWith. Покажите, как фильтруете.
Записан
Странник
Крякер
Offline
Сообщений: 310
Re: Вопросы по QTableView
«
Ответ #7 :
Июль 21, 2011, 10:40 »
Цитата: Авварон от Июль 20, 2011, 18:49
ну я 1 колонку фильтровал через startsWith. Покажите, как фильтруете.
фильтры по StartsWith работают нормально, тормоза замечены только на FixedString. но я про сортировку говорил, там вроде негде накосячить:
Код:
QSqlQueryModel *model = new QSqlQueryModel;
QSortFilterProxyModel *proxyModel = new QSortFilterProxyModel;
proxyModel->setDynamicSortFilter(true);
proxyModel->setSourceModel(model);
QTableView *tableView = new QTableView;
tableView->setSortingEnabled(true);
tableView->setModel(proxyModel);
увы и ах, уже при ~150 записях заметная задержка, сделал сортировку на сервере.
Записан
PavelVX
Самовар
Offline
Сообщений: 154
Re: Вопросы по QTableView
«
Ответ #8 :
Июль 22, 2011, 05:24 »
а можно как-то перехватывать нажатия на значек сортировок?
если модель QSqlQueryModel, tableView->setSortingEnabled(true);
то при нажатии на треугольнички сортировка не происходит. Вот это бы нажатие и перехватывать. Тогда можно было бы как угодно извращать сортировки. Типа раз нажали на 5 колонку, то и сортируем по нужному столбцу.
Кстати, возвращаясь к сортировкам: типы сортировок можно как-то указывать? Или сортировка всегда отдается на сервер, если вы данные берете с сервера? Просто с сортировкам на сервере есть и минус: на постгре серваках линуксовых сортировка не учитывает пробелы и прочие спецсимволы, что очень неудобно.
Записан
Странник
Крякер
Offline
Сообщений: 310
Re: Вопросы по QTableView
«
Ответ #9 :
Июль 22, 2011, 09:12 »
после нажатия на треугольничек вызывается функция sort(int column, Qt::SortOrder order) модели. переопределяйте и сортируйте - хотите белочку, хотите зайчика.
«
Последнее редактирование: Июль 22, 2011, 09:14 от Странник
»
Записан
PavelVX
Самовар
Offline
Сообщений: 154
Re: Вопросы по QTableView
«
Ответ #10 :
Июль 22, 2011, 10:27 »
оффтоп: нас тут вином угостили, у человека праздник. И тут я читаю про белочку ... в начале даже не понял про какую идет речь, вроде по чуть-чуть совсем выпили.
По существу: ламерский вопрос, поисковик не помогает, разбирать sql строку запроса считаю неправильным.
А как мне по номеру колонки из QSqlQueryModel вытащить имя самой колонки?
void TestModel::sort(int column, Qt::SortOrder order) //наследник от QSqlQueryModel
{
//тут как-то надо по номеру вытащить название, что бы в refresh правильно прописать order by
}
Или это как-то по другому делается
Записан
kambala
phpBB Житель матрицы
Offline
Сообщений: 1247
Re: Вопросы по QTableView
«
Ответ #11 :
Июль 22, 2011, 10:52 »
headerData() ?
Записан
K.A.M.B.A.L.A.: Kinetic Artificial Machine Built for Assassination and Logical Analysis
Странник
Крякер
Offline
Сообщений: 310
Re: Вопросы по QTableView
«
Ответ #12 :
Июль 22, 2011, 11:03 »
в
headerData()
может храниться произвольный текст. имя колонки можно узнать в
QSqlQueryModel::record().fieldName(int index)
.
Записан
PavelVX
Самовар
Offline
Сообщений: 154
Re: Вопросы по QTableView
«
Ответ #13 :
Июль 22, 2011, 11:05 »
в headerData() указывается ваше название, которое может не совпадать с основным!
Хмм, пока писал, Странник уже ответил
Странник СПАСИБО!
Похоже создав несколько форм и поднакопив опыт удобнее будет написать свою модель и основывать на ней свои формы.
«
Последнее редактирование: Июль 22, 2011, 11:10 от PavelVX
»
Записан
Danila_Bagrofff
Самовар
Offline
Сообщений: 153
Сила в правде!
Re: Вопросы по QTableView
«
Ответ #14 :
Декабрь 22, 2011, 20:20 »
Снова хочу поднять эту тему. Встал вопрос сортировок более глобально.
Если работа с базами данных ведется активно, есть много пользователей, читающих данные из больших таблиц, то запросы с условием order by начинают грузить сервер, создавать блокировки на изменение данных в таблицах и т.д.
Условие order by заставляет всегда прочитать всю таблицу для данной сессии в память. Если у вас используются joinы плюсуйте и эти таблицы. Каждый клиент при работе с бд заставляет заново перечитывать таблицу и держать в кэше все эти данные, загружая сервак. А если данные еще и пишутся в эти таблицу - то тут поднимаются еще и опросы блокировок или актуальности данных на момент чтения. Операция сортировки зачастую может составлять до 90% всего времени запроса. Чем больше эта таблица - тем дольше проходит сортировка.
В общем получается так, что иногда проще выполнять сортировку на клиенте, чтобы меньше загружать сервер БД.
Весь вопрос упирается в то, где все-таки лучше делать сортировку.
С одной стороны лучше на клиенте:
-если вы уверены, что данные не изменились, или они в БД доступны только для чтения
- что загружать сервер БД - критично, существует много обращений на запись
- если таблицы относительно невелики, гонять по сети большие таблицы - тоже не есть гут.
Лучше делать на сервере order by.
- если мало постоянных изменений, и больше чтения, и чтения не так уж и много.
- если таблица очень большая и сортировка на клиенте явно менее производительнее.
Теперь вопрос, как действительно бы лучше делать сортировку данных именно на клиенте?
- строковых
- данных
- целых
Какие механизмы самые оптимальные? Может, есть коды?
«
Последнее редактирование: Декабрь 23, 2011, 17:21 от Danila_Bagrofff
»
Записан
Win7, WinVista + Qt-4.7.0 + MinGW + QtCreator
Страниц: [
1
]
2
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
=> Архив
===> Программирование
=====> Python
===> Веб программирование
=====> PHP, PERL, CGI
Загружается...