МихаилллҚар. 21, 2018, 3:07 Т.Ж.
Как использовать поиск "или" в QSqlTableModel для SQLite
Здравствуйте.
У меня есть поле со многими checkBox. При выборе нескольких checkBox нужно реализовать поиск в SQLite c помощью QSqlTableModel::setSort() так, чтобы выполнилось условие или тут нашло, или тут, или тут или везде.
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!
Пікірлер
Г
- Геній
- Қыр. 13, 2024, 12:46 Т.Қ.
C++ - Тест 001. Первая программа и типы данных
- Нәтиже:66ұпай,
- Бағалау ұпайлары-1
t
- torgaev_2024
- Қыр. 8, 2024, 6:20 Т.Ж.
C++ - Тест 001. Первая программа и типы данных
- Нәтиже:33ұпай,
- Бағалау ұпайлары-10
Соңғы пікірлер
Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
ВР
Linux жүйесінде файлдарды қалай көшіруге болады Screenshot_20240802-065123.png
Влад РусоковТам. 2, 2024, 1:47 Т.Ж.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
Енді форумда талқылаңыз
Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
BlinCTМаусым 25, 2024, 1 Т.Ж.
BlinCTМамыр 5, 2024, 5:46 Т.Ж.
Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
Вот пример моего кода:
При изменении содержимого 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/ этот ваш последний вопрос уже не имеет прямого отношения к фильтрам в таблице, создавайте, пожалуйста, новые темы для новых вопросов.