Создание запроса
Пытаюсь сформировать такого содержания запрос:
SELECT * FROM table WHERE Name = '%Имя%'
Пишу следующее:
QString serchStr = ""; switch (ui->serchComboBox->currentIndex()) { case 1: serchStr = TABLE_REG_NUMBER; break; case 2: serchStr = TABLE_SHIFR; break; case 3: serchStr = TABLE_NAME; break; case 4: serchStr = TABLE_DATE; break; case 5: serchStr = TABLE_UZEL; break; default: break; } QSqlQuery query; QString str = QString("SELECT * FROM " TABLE " WHERE " + serchStr + " = '%1';").arg(arg1); query.prepare(str); query.exec(); query.next(); modelMain->select();
Ничего не происходит. Что я делаю не так? И как в SQLite сделать выборку по неполному соответствию - типа %Имя%.
2
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, установлены. Кроме одного... Когда пытаюсь скомпилиров…
- ИМNov. 22, 2024, 9:51 p.m.Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
- Now discuss on the forum
- fFeb. 15, 2025, 1:46 p.m.Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
- Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
- Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
- Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
По идее строка формируется правильно, но почему-то что-то не работает. Я уже сталкивался с таким поведением, но так и не понял, из-за чего конкретно так происходит. Кажется, я в своё время обошёл эту проблему, когда всё перенёс в метод arg()
Для выборки по неполному соответствию используйте оператор LIKE , он поддерживается в SQLite3
Знак процента означает любое количество символов.
Запрос в самом SQLiteStudio работает. В программе не хочет.
Какой именно запрос? LIKE-запрос? Или изначальный?
Пробовали для начала прописать запрос одной строкой вручную? Чтобы проверить, работает ли в принципе? А то может тот метод и не вызывается вовсе или ещё какая другая причина. в этот запросе особо и ломаться нечему.
Возможно ещё метод prepare() лишний, поскольку не выполняются методы bindValue() после него.
Вместо такой записи:
Сделайте так:
Результат тот же.
Вот полный код в текущей редакции. Через отладчик видно, что запрос формируется верно (точно такой же отлично работает в SQLiteStudio). Везде query.exec(); и query.next(); возвращают true.
Если написать даже цельной строкой так:
Результата ноль.
Через отладчик видно, что функция вызывается и отрабатывает полностью без ошибок - все значения от query.exec(str), query.next() и modelMain->select() через qDebug() возвращают true. сама строка str содержит правильный запрос (он же в SQLiteStudio работает). Сам запрос в переменной str:
"SELECT * FROM table WHERE Name LIKE '%Е%'"
Меня сейчас один момент напряг в этой строке. Не могу понять - это опечатка, или у вас таблица действительно имеет название table ? Если название таблицы table , то переименуйте её... с таким названием работать не будет, я уже нарывался на такой интересный момент. Даже не знаю баг ли это, но не работают запросы, если таблица называется table в любом регистре. Хотя по отладчику всё будет нормально и методы будут возвращать true, но просто это не работает и хоть ты тресни, работать не будет.
Нет таблица называется main, а table я написал чтобы лучше воспринималось.
Подумал может и название main чем-то не угодило - переименовал в draw. Не идет все равно. Перерыл материалы по Qt - все должно работать./p>
Нашел еще один вариант:
Хотя хочется на будущее понять где грабли лежат.
Если кому пригодится - интерактивный поиск по неполному соответствию реализовал так:
Реализации через
Через QSqlQueryModel тоже все работает.
А у меня тут один вопрос возник. Видимо я не правильно понял изначальную суть того, что Вы пытались сделать. А ведь Вы пытались с помощью QSqlQuery выполнить фильтрацию в модели данных modelMain ? Не так ли?
Если так, то это никогда бы у Вас и не заработало. В данном случае QSqlQuery и QSqlTableModel - это абсолютно разные сущности, которые никак не связаны. Я то подумал, что вы пытаетесь просто получить данные через QSqlQuery, а вы оказывается пытались фильтр на модель навешать. Что в корне не верно.
QSqlQuery наверняка работает, только вы не видите результата в QSqlTableModel, поскольку query к ней вообще никакого отношения не имеет.
Да, я как раз и хотел отфильтровать данные.
Меня тоже интересовал вопрос связи QSqlQuery и QSqlTableModel и я хотел задать его позже.
Как забрать данные из query уже знаю и проверил - оказывается запрос все время работал корректно.
Спасибо за помощь и извините за неправильно заданный вопрос :)