R
RED_Spider10 березня 2020 р. 08:40

Qt MYSQL Select из двух таблиц

mysql, Qt

всем привет. столкнулся с такой проблемой
если в mysql workbench написать такой запрос

SELECT A.name_item, A.item_id, B.item_id, B.status_ticket FROM ad_items A, ad_moderation B WHERE A.item_id = B.item_id;

все правильно работает.
но если в коде написать

        QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket "
                                  "FROM ad_items A, ad_moderation B"
                                  "WHERE A.item_id = B.item_id");

получаю ошибку

 QSqlError("1064", "QMYSQL: Unable to execute query", "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'A.item_id = B.item_id' at line 1")

вопрос в чем проблема, не могу понять

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

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

6
Evgenii Legotckoi
  • 10 березня 2020 р. 08:59
  • Відповідь була позначена як рішення.

Добрый день,

А если в одну строку написать?

 QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket FROM ad_items A, ad_moderation B WHERE A.item_id = B.item_id");

Ну и возможно, что стоит экранировать выражения

так

 QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket FROM ad_items A, ad_moderation B WHERE 'A.item_id = B.item_id'");

или так

 QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket FROM ad_items A, ad_moderation B WHERE 'A.item_id' = 'B.item_id'");

Я точно не помню правильный синтаксис, давно не писал SQL запросы в Qt

    R
    • 10 березня 2020 р. 09:19

    "А если в одну строку написать? "

    Большое спасибо,
    так это помогло, спасибо, хотя не понимаю в чем проблема так как перевод строки делал как всегда
    жесть час времени гугла, просто зря потрачена была из-за пустяка

      Evgenii Legotckoi
      • 10 березня 2020 р. 09:22

      А вот теперь я точно знаю, в чём ошибка была.

      Вот ваш код

      QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket "
                                "FROM ad_items A, ad_moderation B"
                                "WHERE A.item_id = B.item_id");
      

      А нужно было написать так

      QString n_query = QString("SELECT A.name_item, A.item_id, B.item_id, B.status_ticket "
                                "FROM ad_items A, ad_moderation B "
                                "WHERE A.item_id = B.item_id");
      

      Видите ошибку?

        R
        • 10 березня 2020 р. 09:40

        так, пробел после B )))))

          Evgenii Legotckoi
          • 10 березня 2020 р. 09:43

          ага, наверное, теперь ещё обиднее за час времени гугла? )))

            R
            • 10 березня 2020 р. 09:47

            конечно да))) но зато я теперь буду помнить что нужно проверять пробелы в запросах))))

              Коментарі

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

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

              • Результат:90бали,
              • Рейтинг балів8
              МВ

              Qt - Тест 001. Сигналы и слоты

              • Результат:68бали,
              • Рейтинг балів-1
              ЛС

              C++ - Тест 001. Первая программа и типы данных

              • Результат:53бали,
              • Рейтинг балів-4
              Останні коментарі
              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 аналогично. Могу предположить, что из-за более новой верси…
              k
              kmssr08 лютого 2024 р. 18:43
              Qt Linux - Урок 001. Автозапуск програми Qt під Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
              АК
              Анатолий Кононенко05 лютого 2024 р. 01:50
              Qt WinAPI - Урок 007. Робота з ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
              Тепер обговоріть на форумі
              J
              JacobFib17 жовтня 2024 р. 03:27
              добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
              ИМ
              Игорь Максимов03 жовтня 2024 р. 04:05
              Реализация навигации по разделам Спасибо Евгений!
              JW
              Jhon Wick01 жовтня 2024 р. 15:52
              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…
              КГ
              Кирилл Гусарев27 вересня 2024 р. 09:09
              Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
              F
              Fynjy22 липня 2024 р. 04:15
              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

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