ЮрийDec. 29, 2021, 1:45 p.m.
Сортировка по дате и времени QSortFilterProxyModel QSqlRelationalTableModel
Добрый вечер.
Хочу сортировать в QTableView по заголовку колонки по дате и времени, сейчас сортирует как строку.
Данные беру из БД SQLite, тип записи DATETIME.
void Equipment::initTableGoods() { dataBase->connOpen(); modelGoods = new QSqlRelationalTableModel(this); modelGoods->setTable("goods"); modelGoods->setFilter("goods.active = '1'"); modelGoods->setRelation(1, QSqlRelation("ref_type", "id", "name")); modelGoods->setRelation(2, QSqlRelation("ref_goods", "id", "name")); modelGoods->setRelation(3, QSqlRelation("ref_mol", "id", "name")); modelGoods->setRelation( 8, QSqlRelation("ref_condition", "id_ref_condition", "name_ref_condition")); modelGoods->setRelation(12, QSqlRelation("ref_location", "id_ref_location", "name_ref_location")); modelGoods->setHeaderData(1, Qt::Horizontal, tr("Тип")); modelGoods->setHeaderData(2, Qt::Horizontal, tr("Наименование")); modelGoods->setHeaderData(3, Qt::Horizontal, tr("МОЛ")); modelGoods->setHeaderData(4, Qt::Horizontal, tr("MAC")); modelGoods->setHeaderData(5, Qt::Horizontal, tr("IP")); modelGoods->setHeaderData(6, Qt::Horizontal, tr("S/N")); modelGoods->setHeaderData(7, Qt::Horizontal, tr("Инвентарный номер")); modelGoods->setHeaderData(8, Qt::Horizontal, tr("Статус")); modelGoods->setHeaderData(9, Qt::Horizontal, tr("Имя устройства в сети")); modelGoods->setHeaderData(10, Qt::Horizontal, tr("Статус")); modelGoods->setHeaderData(11, Qt::Horizontal, tr("Расположение")); modelGoods->setHeaderData(12, Qt::Horizontal, tr("Расположение")); modelGoods->setHeaderData(13, Qt::Horizontal, tr("Доступность")); modelGoods->setHeaderData(15, Qt::Horizontal, tr("Комментарий")); modelGoods->setHeaderData(16, Qt::Horizontal, tr("Последние обновления")); modelGoods->select(); sort->setSourceModel(modelGoods); ui->tableView->setModel(sort); // Устанавливаем модель на TableView ui->tableView->setColumnHidden(0, true); // Скрываем колонку ui->tableView->setColumnHidden(10, true); // Скрываем колонку ui->tableView->setColumnHidden(11, true); // Скрываем колонку ui->tableView->setColumnHidden(14, true); // Скрываем колонку // Разрешаем выделение строк ui->tableView->setSelectionBehavior(QAbstractItemView::SelectRows); // Устанавливаем режим выделения лишь одной строки в таблице ui->tableView->setSelectionMode(QAbstractItemView::SingleSelection); // Устанавливаем размер колонок по содержимому ui->tableView->resizeColumnsToContents(); ui->tableView->setEditTriggers(QAbstractItemView::NoEditTriggers); // Запрещаем редактирование ui->tableView->horizontalHeader()->setStretchLastSection( true); // Растягиваем последнюю колонку по всему tableView dataBase->connClose(); }
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
- Дмитрий
- May 7, 2024, 9:40 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:60points,
- Rating points-1
d
- dsfs
- April 26, 2024, 4:56 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
Last comments
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоFeb. 5, 2024, 1:50 a.m.
EVADec. 25, 2023, 10:30 a.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
добавить qlineseries в функции в функции: "GPlotter::addSeries(QString title, QVector &arr)" я вызываю метод setChart(...), я в конструктор передал адрес на QChartView элемент
BlinCTMay 5, 2024, 5:46 a.m.
Best Indian Food Restaurant In Cincinnati OH Ready to embark on a gastronomic journey like no other? Join us at App india restaurant and discover why we're renowned as the Best Indian Food Restaurant In Cincinnati OH . Whether y…
Evgenii LegotckoiMay 2, 2024, 2:07 p.m.
IscanderCheApril 30, 2024, 4:22 a.m.
Добрый день.
Наследуйте модель сортировки от QSortFilterProxyModel и переопределите метод QSortFilterProxyModel::lessThan таким образом, чтобы вы забирали через индексы дату и время из модели, создавали бы объекты QDateTime и сравнивали бы их друг с другом, тогда это будет работать. Но конкретно для этой колонки, для всех остальных вызывайте методы базового класса.