Юрий
ЮрийЖел. 29, 2021, 1: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, 9:35 Т.Ж.
  • Жауап шешім ретінде белгіленді.

Добрый день.

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

    Пікірлер

    Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
    Кіріңіз немесе Тіркеліңіз
    AD

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

    • Нәтиже:50ұпай,
    • Бағалау ұпайлары-4
    m
    • molni99
    • Қаз. 26, 2024, 1:37 Т.Ж.

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

    • Нәтиже:80ұпай,
    • Бағалау ұпайлары4
    m
    • molni99
    • Қаз. 26, 2024, 1:29 Т.Ж.

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

    • Нәтиже:20ұпай,
    • Бағалау ұпайлары-10
    Соңғы пікірлер
    ИМ
    Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
    Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    Evgenii Legotckoi
    Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
    A
    ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
    Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
    ИМ
    Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
    d
    dblas5Шілде 5, 2024, 11:02 Т.Ж.
    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
    Енді форумда талқылаңыз
    m
    moogoҚар. 22, 2024, 7:17 Т.Ж.
    Mosquito Spray System Effective Mosquito Systems for Backyard | Eco-Friendly Misting Control Device & Repellent Spray - Moogo ; Upgrade your backyard with our mosquito-repellent device! Our misters conce…
    Evgenii Legotckoi
    Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
    t
    tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
    NSProject
    NSProjectМаусым 4, 2022, 3:49 Т.Ж.
    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

    Бізді әлеуметтік желілерде бақылаңыз