Юрий
30 грудня 2021 р. 00: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();
}

2

Вам це подобається? Поділіться в соціальних мережах!

1
Evgenii Legotckoi
  • 30 грудня 2021 р. 20:35
  • Відповідь була позначена як рішення.

Добрый день.

Наследуйте модель сортировки от QSortFilterProxyModel и переопределите метод QSortFilterProxyModel::lessThan таким образом, чтобы вы забирали через индексы дату и время из модели, создавали бы объекты QDateTime и сравнивали бы их друг с другом, тогда это будет работать. Но конкретно для этой колонки, для всех остальных вызывайте методы базового класса.

    Коментарі

    Only authorized users can post comments.
    Please, Log in or Sign up
    • Останні коментарі
    • Evgenii Legotckoi
      16 квітня 2025 р. 17:08
      Благодарю за отзыв. И вам желаю всяческих успехов!
    • IscanderChe
      12 квітня 2025 р. 17:12
      Добрый день. Спасибо Вам за этот проект и отдельно за ответы на форуме, которые мне очень помогли в некоммерческих пет-проектах. Профессиональным программистом я так и не стал, но узнал мно…
    • AK
      01 квітня 2025 р. 11:41
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      09 березня 2025 р. 21:02
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      09 березня 2025 р. 16:14
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…