Arrow
ArrowMarch 23, 2017, 11:34 a.m.

Создание запроса

Пытаюсь сформировать такого содержания запрос:

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 сделать выборку по неполному соответствию - типа %Имя%.

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

16
Evgenii Legotckoi
  • March 23, 2017, 12:44 p.m.

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

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

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

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

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

    Arrow
    • March 24, 2017, 3:20 a.m.

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

      Evgenii Legotckoi
      • March 24, 2017, 3:37 a.m.

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

        Evgenii Legotckoi
        • March 24, 2017, 3:51 a.m.

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

          Evgenii Legotckoi
          • March 24, 2017, 4 a.m.

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

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

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

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

          query.exec(str);
            Arrow
            • March 24, 2017, 7:26 a.m.

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

            Вот полный код в текущей редакции. Через отладчик видно, что запрос формируется верно (точно такой же отлично работает в 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
              • March 24, 2017, 7:33 a.m.

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

                Arrow
                • March 24, 2017, 7:35 a.m.
                "SELECT * FROM table WHERE Name LIKE '%Е%'"

                  Evgenii Legotckoi
                  • March 24, 2017, 2:02 p.m.
                  QString str = QString("SELECT * FROM table WHERE Name LIKE '%d%'");

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

                    Arrow
                    • March 24, 2017, 3:31 p.m.

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

                      Arrow
                      • March 24, 2017, 3:50 p.m.

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

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

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

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

                        Arrow
                        • March 24, 2017, 5:27 p.m.
                        • The answer was marked as a solution.

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

                        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
                          • March 24, 2017, 5:27 p.m.

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

                          QSqlQuery не нашел.
                            Arrow
                            • March 24, 2017, 5:36 p.m.

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

                              Evgenii Legotckoi
                              • March 26, 2017, 6:47 a.m.

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

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

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

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

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

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

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

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

                                  Comments

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

                                  C ++ - Test 004. Pointers, Arrays and Loops

                                  • Result:50points,
                                  • Rating points-4
                                  m

                                  C ++ - Test 004. Pointers, Arrays and Loops

                                  • Result:80points,
                                  • Rating points4
                                  m

                                  C ++ - Test 004. Pointers, Arrays and Loops

                                  • Result:20points,
                                  • Rating points-10
                                  Last comments
                                  Evgenii Legotckoi
                                  Evgenii LegotckoiOct. 31, 2024, 9:37 p.m.
                                  Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                                  A
                                  ALO1ZEOct. 19, 2024, 3:19 p.m.
                                  Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                  ИМ
                                  Игорь МаксимовOct. 5, 2024, 2:51 p.m.
                                  Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                  d
                                  dblas5July 5, 2024, 6:02 p.m.
                                  QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                  k
                                  kmssrFeb. 9, 2024, 2:43 a.m.
                                  Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
                                  Now discuss on the forum
                                  Evgenii Legotckoi
                                  Evgenii LegotckoiJune 24, 2024, 10:11 p.m.
                                  добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                  t
                                  tonypeachey1Nov. 15, 2024, 2:04 p.m.
                                  google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                                  NSProject
                                  NSProjectJune 4, 2022, 10:49 a.m.
                                  Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                                  9
                                  9AnonimOct. 25, 2024, 4:10 p.m.
                                  Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                  Follow us in social networks