Юрий
Юрий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
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

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

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

Добрый день.

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

    Коментарі

    Only authorized users can post comments.
    Please, Log in or Sign up
    m
    • molni99
    • 26 жовтня 2024 р. 08:37

    C++ - Тест 004. Указатели, Массивы и Циклы

    • Результат:80бали,
    • Рейтинг балів4
    m
    • molni99
    • 26 жовтня 2024 р. 08:29

    C++ - Тест 004. Указатели, Массивы и Циклы

    • Результат:20бали,
    • Рейтинг балів-10

    C++ - Тест 003. Условия и циклы

    • Результат:42бали,
    • Рейтинг балів-8
    Останні коментарі
    A
    ALO1ZE19 жовтня 2024 р. 15:19
    Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
    ИМ
    Игорь Максимов05 жовтня 2024 р. 14:51
    Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
    d
    dblas505 липня 2024 р. 18:02
    QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
    k
    kmssr09 лютого 2024 р. 02:43
    Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
    АК
    Анатолий Кононенко05 лютого 2024 р. 09:50
    Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
    Тепер обговоріть на форумі
    jd
    jasmine disouza28 жовтня 2024 р. 11:58
    GeForce Now India: Unlocking the Future of Cloud Gaming GeForce Now India has a major impact on the gaming scene by introducing NVIDIA's cloud gaming service to Indian gamers. GeForce Now India lets you stream top-notch PC games on any device, from b…
    9
    9Anonim25 жовтня 2024 р. 16:10
    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
    J
    JacobFib17 жовтня 2024 р. 10:27
    добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
    ИМ
    Игорь Максимов03 жовтня 2024 р. 11:05
    Реализация навигации по разделам Спасибо Евгений!
    JW
    Jhon Wick01 жовтня 2024 р. 22:52
    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…

    Слідкуйте за нами в соціальних мережах