Реклама

Qt/C++ - Урок 007. Фильтр для записей в QSqlTableModel

QSqlRelationalTableModel, QSqlTableModel, QSqlTableModel example, фильтр

Продолжая работу с таблицами в Qt , хотелось бы освятить тот момент, как установить фильтр на модель представления данных в QSqlTableModel или в QSqlRelationalTableModel . Поэтому для описания процесса установки фильтра за основу был взят программный код из урока по QSqlTableModel .

Программный код был написан в QtCreator 3.3.1 на основе Qt 5.4.1.

Структура проекта

В данном уроке структура проекта остается аналогичной проекту из урока по QSqlTableModel.

mainwindow.ui

Внесём дополнительные объекта в главное окно приложения, а именно добавим следующие элементы:

  • dateEditFROM - начальная дата;
  • dateEditTO - конечная дата;
  • timeEditFROM - начальное время;
  • timeEditTO - конечное время;
  • pushButton - кнопка, по нажатию которой будет применяться фильтр.

mainwindow.h

В заголовочном фильтре добавляется СЛОТ для обработки нажатия кнопки, в который будет зашит фильтр для таблицы.

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

 ***

namespace Ui {
class MainWindow;
}

class MainWindow : public QMainWindow
{
    Q_OBJECT

 ***

private slots:
    void on_pushButton_clicked();

 ***

};

#endif // MAINWINDOW_H

mainwindow.cpp

В данном файле изменяется частично лишь один метод и добавляется СЛОТ для обработки нажатия кнопки.

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ***
}

MainWindow::~MainWindow()
{
    delete ui;
}

/* Метод для инициализации модеи представления данных
 * */
void MainWindow::setupModel(const QString &tableName, const QStringList &headers)
{
    ***
}

void MainWindow::createUI()
{
    ***

    /* Устанавливаем в объекты даты для фильтра текущую дату
     * */
    ui->dateEditFROM->setDate(QDate::currentDate());
    ui->dateEditTO->setDate(QDate::currentDate());
    
    /* Вызываем метод, в котором устанавливается фильтр на таблицу
     * */
    on_pushButton_clicked();
}

/* Метод для обработки нажатия кнопки
 * и по совместительству фильтр для модели
 * представления табличный данных
 * */
void MainWindow::on_pushButton_clicked()
{
    /* Установка фильтра представляет из себя часть SQL запроса
     * который начинается после слова WHERE в SQL запросе.
     * Следовательно для специалистов, работавших с SQL не составит труда
     * сформировать нужный фильтр
     * */
    model->setFilter(QString( TABLE_DATE " between '%1' and '%2' and "
                              TABLE_TIME " between '%3' and '%4'")
                     .arg(ui->dateEditFROM->date().toString("yyyy-MM-dd"),
                          ui->dateEditTO->date().toString("yyyy-MM-dd"),
                          ui->timeEditFROM->time().toString("hh:mm:ss"),
                          ui->timeEditTO->time().toString("hh:mm:ss")));
    model->select();
}

Примечание. Для установки фильтра в QSqlQueryModel необходимо просто задать соответствующую фильтрацию в SQL запросе, который отправляется в данную модель.

database.h и database.cpp

В данные файлы не вносятся абсолютно никакие изменения.

Итог

В результате у Вас должно получится приложение следующего вида с возможностью фильтрации записей в таблице по дате и времени.

Реклама

Комментарии

Комментарии

Только авторизованные пользователи могут оставлять комментарии.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
  • falcon
  • 16 января 2018 г. 17:25

Qt - Тест 001. Сигналы и слоты

  • Результат 100 баллов
  • Очки рейтинга 10
  • falcon
  • 16 января 2018 г. 17:22

Qt - Тест 001. Сигналы и слоты

  • Результат 68 баллов
  • Очки рейтинга -1
  • falcon
  • 16 января 2018 г. 17:18

C++ - Тест 001. Первая программа и типы данных

  • Результат 73 баллов
  • Очки рейтинга 1
Последние комментарии

QML - Урок 021. Переключение между окнами в QML

Спасибо всем. Все получилось. Прикручиваю логику.

  • BlinCT
  • 14 января 2018 г. 19:28

Разработка на Qt под iOS

Вот честно, на сколько же муторно под огрызок что то делать. Куча проблем) А вод линь или под Андроид все просто и тривиально))

  • folax
  • 12 января 2018 г. 9:16

QML - Урок 021. Переключение между окнами в QML

Ничего сложного, делаете по тех заданию 3 файла qml, называете их как указанно в тех задании, потом из первого окна через Loader их переключаете, в окне 2 и 3 делаете сигналы которые при закры...

QML - Урок 021. Переключение между окнами в QML

Все верно, я и не говорил что этот кусок кода лично мое произведение. Это тоже верно: Это задание для прохождения на собеседование в одну из крупных украинских IT компаний. Логику ...

  • folax
  • 12 января 2018 г. 8:13

QML - Урок 021. Переключение между окнами в QML

int main(int argc, char *argv[]){ QApplication app(argc, argv); Logic logic; QQmlApplicationEngine engine; engine.rootContext()->setContextProperty("logic", &logic)...

Сейчас обсуждают на форуме

ChartView. Отображение метки данных точки серии при наведении курсора

Спасибо большущее за советы! Все получилось через ScatterSeries. Методы remove() как-то сходу не дались, удаляет в первый раз, а потом программа падает... Не стал тратить время и воспользовалс...

  • EVILEG
  • 16 января 2018 г. 14:23

Как проверить доступность сервера

Добрый день! Теоретически можно использовать QTcpSocket, у него есть метод connectToHost. Возможно, что проверка доступности через этот класс будет осуществляться несколько быстрее,...

QGraphicsScene

спасибо, за подробное объяснение строчки, а с зумом я разобрался, все работает

  • EVILEG
  • 15 января 2018 г. 17:21

Qt webgl

Насчёт проверки подключения клиента я не в курсе. Что касается экземпляров приложения, то из того, что я читал получается, что нет необходимости в нескольких экземплярах для нескольких кл...

  • EVILEG
  • 15 января 2018 г. 11:39

Проблема добавления #DEFINE при сборке CMak'ом

А Вы не пробовали сделать предкомпилированные библиотеки boost под свою систему, а потом уже подключать собранные библиотеки Boost`а? Просто один только boost может собираться на пару гиг...