Arrow23 марта 2017 г. 11:34
Создание запроса
Пытаюсь сформировать такого содержания запрос:
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 сделать выборку по неполному соответствию - типа %Имя%.
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
d
- dsfs
- 26 апреля 2024 г. 16:56
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80баллов,
- Очки рейтинга4
d
- dsfs
- 26 апреля 2024 г. 16:35
C++ - Тест 001. Первая программа и типы данных
- Результат:73баллов,
- Очки рейтинга1
Последние комментарии
Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко5 февраля 2024 г. 14:50
EVA25 декабря 2023 г. 23:30
Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Сейчас обсуждают на форуме
Best Indian Food Restaurant In Cincinnati OH Ready to embark on a gastronomic journey like no other? Join us at App india restaurant and discover why we're renowned as the Best Indian Food Restaurant In Cincinnati OH . Whether y…
Evgenii Legotckoi3 мая 2024 г. 2:07
IscanderChe30 апреля 2024 г. 16:22
Павел Дорофеев14 апреля 2024 г. 14:35
По идее строка формируется правильно, но почему-то что-то не работает. Я уже сталкивался с таким поведением, но так и не понял, из-за чего конкретно так происходит. Кажется, я в своё время обошёл эту проблему, когда всё перенёс в метод 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:
Меня сейчас один момент напряг в этой строке. Не могу понять - это опечатка, или у вас таблица действительно имеет название table ? Если название таблицы table , то переименуйте её... с таким названием работать не будет, я уже нарывался на такой интересный момент. Даже не знаю баг ли это, но не работают запросы, если таблица называется table в любом регистре. Хотя по отладчику всё будет нормально и методы будут возвращать true, но просто это не работает и хоть ты тресни, работать не будет.
Нет таблица называется main, а table я написал чтобы лучше воспринималось.
Подумал может и название main чем-то не угодило - переименовал в draw. Не идет все равно. Перерыл материалы по Qt - все должно работать./p>
Нашел еще один вариант:
Хотя хочется на будущее понять где грабли лежат.
Если кому пригодится - интерактивный поиск по неполному соответствию реализовал так:
Реализации через
Через QSqlQueryModel тоже все работает.
А у меня тут один вопрос возник. Видимо я не правильно понял изначальную суть того, что Вы пытались сделать. А ведь Вы пытались с помощью QSqlQuery выполнить фильтрацию в модели данных modelMain ? Не так ли?
Если так, то это никогда бы у Вас и не заработало. В данном случае QSqlQuery и QSqlTableModel - это абсолютно разные сущности, которые никак не связаны. Я то подумал, что вы пытаетесь просто получить данные через QSqlQuery, а вы оказывается пытались фильтр на модель навешать. Что в корне не верно.
QSqlQuery наверняка работает, только вы не видите результата в QSqlTableModel, поскольку query к ней вообще никакого отношения не имеет.
Да, я как раз и хотел отфильтровать данные.
Меня тоже интересовал вопрос связи QSqlQuery и QSqlTableModel и я хотел задать его позже.
Как забрать данные из query уже знаю и проверил - оказывается запрос все время работал корректно.
Спасибо за помощь и извините за неправильно заданный вопрос :)