Arrow23. März 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
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.Magst du es? In sozialen Netzwerken teilen!
Kommentare
sf
- sdfsdfkp fgskpgokspdog
- 14. Oktober 2024 15:09
C++ - Тест 004. Указатели, Массивы и Циклы
- Ergebnis:90punkte,
- Bewertungspunkte8
МВ
- Максим Васильев
- 2. Oktober 2024 04:14
Qt - Тест 001. Сигналы и слоты
- Ergebnis:68punkte,
- Bewertungspunkte-1
ЛС
- Лев Семенов
- 30. September 2024 11:04
C++ - Тест 001. Первая программа и типы данных
- Ergebnis:53punkte,
- Bewertungspunkte-4
Letzte Kommentare
Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов5. Oktober 2024 07:51
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко5. Februar 2024 01:50
Jetzt im Forum diskutieren
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь Максимов3. Oktober 2024 04:05
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
Кирилл Гусарев27. September 2024 09:09
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
По идее строка формируется правильно, но почему-то что-то не работает. Я уже сталкивался с таким поведением, но так и не понял, из-за чего конкретно так происходит. Кажется, я в своё время обошёл эту проблему, когда всё перенёс в метод 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 уже знаю и проверил - оказывается запрос все время работал корректно.
Спасибо за помощь и извините за неправильно заданный вопрос :)