Юрий29 грудня 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
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 12 листопада 2024 р. 01:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 26 жовтня 2024 р. 11:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 26 жовтня 2024 р. 11:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 22:51
Evgenii Legotckoi01 листопада 2024 р. 00:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 17:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi25 червня 2024 р. 01:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 17:04
NSProject04 червня 2022 р. 13:49
IscanderChe01 листопада 2024 р. 01:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Добрый день.
Наследуйте модель сортировки от QSortFilterProxyModel и переопределите метод QSortFilterProxyModel::lessThan таким образом, чтобы вы забирали через индексы дату и время из модели, создавали бы объекты QDateTime и сравнивали бы их друг с другом, тогда это будет работать. Но конкретно для этой колонки, для всех остальных вызывайте методы базового класса.