Юрий
Юрий15 лютого 2020 р. 11:31

Как обрабатывать ошибки при использовании QSqlTableModel

Добрый вечер.
Как обработать ошибки в запросе?

    QSqlTableModel *model = new QSqlTableModel();
    model->setTable(DataBaseTableName::TABLE);
    model->setFilter("id_user = " + QString::number(id_user));
    model->select();
Делаю так:
model->lastError().text();

Меня смущает только то, что сыпется в debug, даже если ошибки нет
2020-02-15T19:28:33:1 Debug: MyClass::MyMethod>> " "

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

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

6
Ruslan Polupan
  • 16 лютого 2020 р. 05:39

QSqlError после select

    Evgenii Legotckoi
    • 16 лютого 2020 р. 09:04
    • Відповідь була позначена як рішення.

    Если вы делаете так сразу после select

    qDebug() << model->lastError().text();
    

    То всегда будет сыппать хотя бы пустой текст. там просто состояние OK, без ошибок с пустым текстом. Добавляйте qDebug() внутри условия на ошибку.

      ИП
      • 16 лютого 2020 р. 11:35
      #include <QSqlError>
      #include <QSqlQuery>
      ...
      
      if (!model->select())
          {
              qDebug() << model->lastError().text();
              qDebug() << model->query().lastQuery();
          }
      
        Юрий
        • 19 лютого 2020 р. 11:58

        Спасибо, все понятно.

          Юрий
          • 19 лютого 2020 р. 16:14

          А в чем отличие?

          qDebug() << model->lastError().text();
          qDebug() << model->query().lastQuery();
          

          Последний еще возвращает код ошибки, какой вывод использовать приоритетней?

            ИП
            • 19 лютого 2020 р. 23:55

            qDebug() << model->lastError().text() - возвращает текст и код ошибки, который возвращает база данных, чаще всего ошибка бывает из-за неправильного SQL запроса
            qDebug() << model->query().lastQuery() - это SQL запрос, который сформировал QSqlTableModel и отправил на сервер, есть смысл посмотреть на него и, например, отдельно запустить на сервере

              Коментарі

              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 приложения их можно выбрать. В чем может …

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