МихаилллNov. 21, 2018, 3:07 a.m.
Как использовать поиск "или" в QSqlTableModel для SQLite
Здравствуйте.
У меня есть поле со многими checkBox. При выборе нескольких checkBox нужно реализовать поиск в SQLite c помощью QSqlTableModel::setSort() так, чтобы выполнилось условие или тут нашло, или тут, или тут или везде.
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
B
- Bogdannn
- March 27, 2024, 7:15 p.m.
C++ - Test 001. The first program and data types
- Result:46points,
- Rating points-6
Last comments
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоFeb. 5, 2024, 1:50 a.m.
EVADec. 25, 2023, 10:30 a.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
Павел ДорофеевApril 14, 2024, 2:35 a.m.
Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…
Как получить в массив значения из связанной модели? Спасибо, разобрался:))
AC
QML Обнулить значения SpinBox Доброго времени суток, не могу разобраться с обнулением значение SpinBox находящего в делегате. import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: tr…
Alexandru CodreanuJan. 19, 2024, 11:57 a.m.
Вот пример моего кода:
При изменении содержимого lineEdit происходит установка фильтра,
Спасибо.
В 4 строчке ZN и FN это названия столбцов?
Да это название столбцов
Что то у меня не работает.
Если делать так, то запрос выполняется
а если так, то почему-то не выполняется условие или
Тестируйте запросы в менеджере БД, а потом что все после WHERE используйте как аргумент setFilter.
Не плохо бы было увидеть саму таблицу и задачу которая вам необходима для установки фильтра
Я проверял названия столбцов.
Вот код бд
PRAGMA foreign_keys = 0;
CREATE TABLE sqlitestudio_temp_table AS SELECT *
FROM SQLliteResumeArray;
DROP TABLE SQLliteResumeArray;
CREATE TABLE SQLliteResumeArray (
NumberID INTEGER PRIMARY KEY AUTOINCREMENT
NOT NULL
UNIQUE,
Name TEXT,
Gender TEXT,
Age INTEGER,
DateOfBirth DATE,
PhoneNumber TEXT,
Email TEXT,
City TEXT,
BusinessTrip TEXT,
PostDesired TEXT,
Salary INTEGER,
CVPost TEXT,
NameCompany TEXT,
Experiance TEXT,
Languages TEXT,
AdditionalInformation TEXT,
Education TEXT,
Skills TEXT,
Comments TEXT,
Resume TEXT
);
INSERT INTO SQLliteResumeArray (
NumberID,
Name,
Gender,
Age,
DateOfBirth,
PhoneNumber,
Email,
City,
BusinessTrip,
PostDesired,
Salary,
CVPost,
NameCompany,
Experiance,
Languages,
AdditionalInformation,
Education,
Skills,
Comments,
Resume
)
SELECT NumberID,
Name,
Gender,
Age,
DateOfBirth,
PhoneNumber,
Email,
City,
BusinessTrip,
PostDesired,
Salary,
CVPost,
NameCompany,
Experiance,
Languages,
AdditionalInformation,
Education,
Skills,
Comments,
Resume
FROM sqlitestudio_temp_table;
DROP TABLE sqlitestudio_temp_table;
CREATE INDEX IndexResumeArray ON SQLliteResumeArray (
NumberID,
Name,
Age,
DateOfBirth,
PostDesired,
CVPost,
PhoneNumber,
Email,
City,
Salary,
NameCompany,
Education,
Languages,
Experiance,
Gender,
AdditionalInformation,
Comments,
Resume,
BusinessTrip,
Skills
);
PRAGMA foreign_keys = 1;
Сделал базу по вашей таблице
Запрос работает.
Проверьте в своем менеджере БД, возможно у вас база пустая.
во вложении SQL файл с вашей таблицей. Выполните импорт и пробуйте.
Спасибо.
Извините за беспокойство.
Просто запрос написал с маленькой буквы, а в бд он с большой.
Что бы избежать подобных трудностей я всегда тестирую запросы напрямую а потом уже использую их в Qt
Скажите пожалуйста, как добавить по столбу с INTEGER поиск от int a; до int b; ?
разобрался, так
Еще можно так
Или так
Да, ваш вариант правильный, а мой не работал, т.к. оказалось QSqlTableModel запоминает только последний setFilter().
А можно ли сделать сначала один запрос setFilter, а потом искать уже в найденном еще одним setFilter ,и так дальше?
Если не сложно по конкретнее задачу поставьте, на примере таблицы что у вас есть.
Нужно писать вложенные запросы. Или очень сложные фильтры конкретно для QSqlTableModel. Если хотите сохранить предыдущий запрос, то выполняйте это вручную в какую-нибудь переменную.
Ну или создавать временные таблицы в базе данных сырыми запросами, но это ещё сложнее будет.
На примере этой таблицы:
Сначала Age от 30 до 40
Потом Languages Languages LIKE ('Russian%')
Потом Languages City LIKE ('Москва%')
И так дальше. Просто количество фильтров не ограниченно и критерии поиска могут быть разнообразны.
С помощью вложенных запросов врятли получится так написать.
Если в переменную записывать, выйдет слишком громоздко и не оптимально будет идти поиск.
А как это сделать с помощью сложных фильтров QSqlTableModel?
Тогда использовать QSortFilterProxyModel
https://doc.qt.io/qt-5/qtwidgets-itemviews-customsortfiltermodel-example.html
Либо пересмотреть структуру БД, для оптимизации построения запросов.
Похоже что придется создавать временную таблицу.
Новую таблицу нужно создавать через QSqlQuery?
Не знаете, как новой таблице дать данные из setFilter()?
Пытаюсь создать временную таблицу так, но выдает ошибку QSqlError("1", "Unable to execute statement", "no such column: Name")
Если у вас фильтрация таблицы из разных фильтров, то лучше всё-таки попытаться написать фильтр правильно, например
ну и так далее, главное правильно сформировать фильтрующую запись. Это будет формирование более сложного запроса, но это будет всё-таки легче, чем использовать временную таблицу.
Спасибо.
А можно ли сделать поиск не чувствительным к регистру
У вас база данных SQLite?
Как я понимаю, у неё нет встроенных механизмов, поэтому нужно извращаться, например так
SQLite из коробки не поддерживает кириллицу в UPPER :-(
То есть, решение из разряда фантастики стандартными средствами для SQLite?
мне срочно нужно добавлять на сайт смайлики... фейспалма очень не хватает...
А как такой запрос отразится на скорости поиска?
И скажите пожалуйста, как это решение можно добавить в запрос
я думаю, если заменить SQLite на другую БД, например postgresql, то можно будет стандартными средствами этот поиск сделать, без таких извращений. И работать будет быстрее точно. Но пока это у вас не является узким местом, то и не замрочивайтесь. Преждевременная оптимизация тоже не нужна.
А вы не знаете, как в postgresql сделать автозаполнение столбца с ключом?
AUTOINCREMENT
P/S/ этот ваш последний вопрос уже не имеет прямого отношения к фильтрам в таблице, создавайте, пожалуйста, новые темы для новых вопросов.