ArrowНаурыз 23, 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 хостинг.Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!
Пікірлер
AD
- Akiv Doros
- Қар. 11, 2024, 10:58 Т.Қ.
C++ - Тест 004. Указатели, Массивы и Циклы
- Нәтиже:50ұпай,
- Бағалау ұпайлары-4
m
- molni99
- Қаз. 26, 2024, 8:37 Т.Ж.
C++ - Тест 004. Указатели, Массивы и Циклы
- Нәтиже:80ұпай,
- Бағалау ұпайлары4
m
- molni99
- Қаз. 26, 2024, 8:29 Т.Ж.
C++ - Тест 004. Указатели, Массивы и Циклы
- Нәтиже:20ұпай,
- Бағалау ұпайлары-10
Соңғы пікірлер
ИМ
Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь МаксимовҚар. 22, 2024, 7:51 Т.Қ.
Evgenii LegotckoiҚаз. 31, 2024, 9:37 Т.Қ.
Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь МаксимовҚаз. 5, 2024, 2:51 Т.Қ.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Енді форумда талқылаңыз
Mosquito Spray System Effective Mosquito Systems for Backyard | Eco-Friendly Misting Control Device & Repellent Spray - Moogo ; Upgrade your backyard with our mosquito-repellent device! Our misters conce…
Evgenii LegotckoiМаусым 24, 2024, 10:11 Т.Қ.
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey1Қар. 15, 2024, 2:04 Т.Қ.
NSProjectМаусым 4, 2022, 10:49 Т.Ж.
IscanderCheҚаз. 31, 2024, 10:43 Т.Қ.
По идее строка формируется правильно, но почему-то что-то не работает. Я уже сталкивался с таким поведением, но так и не понял, из-за чего конкретно так происходит. Кажется, я в своё время обошёл эту проблему, когда всё перенёс в метод 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 уже знаю и проверил - оказывается запрос все время работал корректно.
Спасибо за помощь и извините за неправильно заданный вопрос :)