Юрий29. Dezember 2021 13:45
Сортировка по дате и времени 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(); }
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.Magst du es? In sozialen Netzwerken teilen!
Kommentare
sf
- sdfsdfkp fgskpgokspdog
- 14. Oktober 2024 15:09
C++ - Тест 004. Указатели, Массивы и Циклы
- Ergebnis:90punkte,
- Bewertungspunkte8
МВ
- Максим Васильев
- 2. Oktober 2024 04:14
Qt - Тест 001. Сигналы и слоты
- Ergebnis:68punkte,
- Bewertungspunkte-1
ЛС
- Лев Семенов
- 30. September 2024 11:04
C++ - Тест 001. Первая программа и типы данных
- Ergebnis:53punkte,
- Bewertungspunkte-4
Letzte Kommentare
ИМ
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов5. Oktober 2024 07:51
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко5. Februar 2024 01:50
EVA25. Dezember 2023 10:30
Jetzt im Forum diskutieren
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь Максимов3. Oktober 2024 04:05
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
Кирилл Гусарев27. September 2024 09:09
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
Добрый день.
Наследуйте модель сортировки от QSortFilterProxyModel и переопределите метод QSortFilterProxyModel::lessThan таким образом, чтобы вы забирали через индексы дату и время из модели, создавали бы объекты QDateTime и сравнивали бы их друг с другом, тогда это будет работать. Но конкретно для этой колонки, для всех остальных вызывайте методы базового класса.