Как использовать поиск "или" в QSqlTableModel для SQLite
Здравствуйте.
У меня есть поле со многими checkBox. При выборе нескольких checkBox нужно реализовать поиск в SQLite c помощью QSqlTableModel::setSort() так, чтобы выполнилось условие или тут нашло, или тут, или тут или везде.
4
252
Do you like it? Share on social networks!
- Last comments
- AKApril 1, 2025, 11:41 a.m.Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
- VPMarch 9, 2025, 4:14 p.m.Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
- Now discuss on the forum
- DTApril 14, 2025, 3:38 p.m.Всем привет! На Qt 6.8 MinGW пытаюсь сделать управление подключением WiFi из программы. Пока делаю поддержку Windows, но так же хочу в дальнейшем внедрить и поддержку Linux/MacOS. Для…
- fFeb. 15, 2025, 1:46 p.m.Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
- Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
- Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
Вот пример моего кода:
При изменении содержимого 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/ этот ваш последний вопрос уже не имеет прямого отношения к фильтрам в таблице, создавайте, пожалуйста, новые темы для новых вопросов.