Arrow
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
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

16
Evgenii Legotckoi
  • 23 березня 2017 р. 12:44

По идее строка формируется правильно, но почему-то что-то не работает. Я уже сталкивался с таким поведением, но так и не понял, из-за чего конкретно так происходит. Кажется, я в своё время обошёл эту проблему, когда всё перенёс в метод arg()

QString str = QString("SELECT * FROM " TABLE " WHERE %1 = '%2';").arg(serchStr).arg(arg1);

Для выборки по неполному соответствию используйте оператор LIKE , он поддерживается в SQLite3

SELECT * FROM table1 WHERE name LIKE '%часть слова%';

Знак процента означает любое количество символов.

    Arrow
    • 24 березня 2017 р. 03:20

    Запрос в самом SQLiteStudio работает. В программе не хочет.

      Evgenii Legotckoi
      • 24 березня 2017 р. 03:37

      Какой именно запрос? LIKE-запрос? Или изначальный?

        Evgenii Legotckoi
        • 24 березня 2017 р. 03:51

        Пробовали для начала прописать запрос одной строкой вручную? Чтобы проверить, работает ли в принципе? А то может тот метод и не вызывается вовсе или ещё какая другая причина. в этот запросе особо и ломаться нечему.

          Evgenii Legotckoi
          • 24 березня 2017 р. 04:00

          Возможно ещё метод prepare() лишний, поскольку не выполняются методы bindValue() после него.

          Вместо такой записи:

          query.prepare(str);
          query.exec();

          Сделайте так:

          query.exec(str);
            Arrow
            • 24 березня 2017 р. 07:26

            Результат тот же.

            Вот полный код в текущей редакции. Через отладчик видно, что запрос формируется верно (точно такой же отлично работает в SQLiteStudio). Везде query.exec(); и query.next(); возвращают true.

            void DrawWidget::on_serchLine_textChanged(const QString &arg1)
            {
                // Поиск в базе данных
            
                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 %1 LIKE '%%2%';").arg(serchStr).arg(arg1);
            
                //query.prepare(str);
                query.exec(str);
                query.next();
            
                modelMain->select();
            }

            Если написать даже цельной строкой так:

            QString str = QString("SELECT * FROM table WHERE Name LIKE '%d%'");

            Результата ноль.

              Arrow
              • 24 березня 2017 р. 07:33

              Через отладчик видно, что функция вызывается и отрабатывает полностью без ошибок - все значения от query.exec(str), query.next() и modelMain->select() через qDebug() возвращают true. сама строка str содержит правильный запрос (он же в SQLiteStudio работает). Сам запрос в переменной str:

                Arrow
                • 24 березня 2017 р. 07:35
                "SELECT * FROM table WHERE Name LIKE '%Е%'"

                  Evgenii Legotckoi
                  • 24 березня 2017 р. 14:02
                  QString str = QString("SELECT * FROM table WHERE Name LIKE '%d%'");

                  Меня сейчас один момент напряг в этой строке. Не могу понять - это опечатка, или у вас таблица действительно имеет название table ? Если название таблицы table , то переименуйте её... с таким названием работать не будет, я уже нарывался на такой интересный момент. Даже не знаю баг ли это, но не работают запросы, если таблица называется table в любом регистре. Хотя по отладчику всё будет нормально и методы будут возвращать true, но просто это не работает и хоть ты тресни, работать не будет.

                    Arrow
                    • 24 березня 2017 р. 15:31

                    Нет таблица называется main, а table я написал чтобы лучше воспринималось.

                      Arrow
                      • 24 березня 2017 р. 15:50

                      Подумал может и название main чем-то не угодило - переименовал в draw. Не идет все равно. Перерыл материалы по Qt - все должно работать./p>

                      Нашел еще один вариант:

                      QString str = QString("SELECT * FROM " TABLE
                                                " WHERE %1 LIKE '%%2%';").arg(serchStr).arg(arg1);
                      
                      QSqlQueryModel model;
                      
                       model.setQuery(str);

                      Хотя хочется на будущее понять где грабли лежат.

                        Arrow
                        • 24 березня 2017 р. 17:27
                        • Відповідь була позначена як рішення.

                        Если кому пригодится - интерактивный поиск по неполному соответствию реализовал так:

                        void DrawWidget::on_serchLine_textChanged(const QString &arg1)
                        {
                            // Поиск в базе данных
                        
                            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;
                            }
                        
                            modelMain->setFilter(serchStr + " LIKE '%" + arg1 + "%'");
                        
                            modelMain->select();
                        }
                          Arrow
                          • 24 березня 2017 р. 17:27

                          Реализации через

                          QSqlQuery не нашел.
                            Arrow
                            • 24 березня 2017 р. 17:36

                            Через QSqlQueryModel тоже все работает.

                              Evgenii Legotckoi
                              • 26 березня 2017 р. 06:47

                              А у меня тут один вопрос возник. Видимо я не правильно понял изначальную суть того, что Вы пытались сделать. А ведь Вы пытались с помощью QSqlQuery выполнить фильтрацию в модели данных modelMain ? Не так ли?

                              Если так, то это никогда бы у Вас и не заработало. В данном случае QSqlQuery и QSqlTableModel - это абсолютно разные сущности, которые никак не связаны. Я то подумал, что вы пытаетесь просто получить данные через QSqlQuery, а вы оказывается пытались фильтр на модель навешать. Что в корне не верно.

                              QSqlQuery наверняка работает, только вы не видите результата в QSqlTableModel, поскольку query к ней вообще никакого отношения не имеет.

                              // Значение из query можно забрать таким образом
                              int i = query.boundValue(1).toInt();
                                Arrow
                                • 26 березня 2017 р. 06:59

                                Да, я как раз и хотел отфильтровать данные.

                                Меня тоже интересовал вопрос связи QSqlQuery и QSqlTableModel и я хотел задать его позже.

                                Как забрать данные из query уже знаю и проверил - оказывается запрос все время работал корректно.

                                Спасибо за помощь и извините за неправильно заданный вопрос :)

                                  Коментарі

                                  Only authorized users can post comments.
                                  Please, Log in or Sign up
                                  AD

                                  C++ - Тест 004. Указатели, Массивы и Циклы

                                  • Результат:50бали,
                                  • Рейтинг балів-4
                                  m
                                  • molni99
                                  • 26 жовтня 2024 р. 01:37

                                  C++ - Тест 004. Указатели, Массивы и Циклы

                                  • Результат:80бали,
                                  • Рейтинг балів4
                                  m
                                  • molni99
                                  • 26 жовтня 2024 р. 01:29

                                  C++ - Тест 004. Указатели, Массивы и Циклы

                                  • Результат:20бали,
                                  • Рейтинг балів-10
                                  Останні коментарі
                                  ИМ
                                  Игорь Максимов22 листопада 2024 р. 11:51
                                  Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                                  Evgenii Legotckoi
                                  Evgenii Legotckoi31 жовтня 2024 р. 14:37
                                  Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                                  A
                                  ALO1ZE19 жовтня 2024 р. 08:19
                                  Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                  ИМ
                                  Игорь Максимов05 жовтня 2024 р. 07:51
                                  Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                  d
                                  dblas505 липня 2024 р. 11:02
                                  QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                  Тепер обговоріть на форумі
                                  Evgenii Legotckoi
                                  Evgenii Legotckoi24 червня 2024 р. 15:11
                                  добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                  t
                                  tonypeachey115 листопада 2024 р. 06:04
                                  google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                                  NSProject
                                  NSProject04 червня 2022 р. 03:49
                                  Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                                  9
                                  9Anonim25 жовтня 2024 р. 09:10
                                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                  Слідкуйте за нами в соціальних мережах