Юрий
Юрий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 г. 5:39

QSqlError после select

    Evgenii Legotckoi
    • 16 февраля 2020 г. 9: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 и отправил на сервер, есть смысл посмотреть на него и, например, отдельно запустить на сервере

              Комментарии

              Только авторизованные пользователи могут публиковать комментарии.
              Пожалуйста, авторизуйтесь или зарегистрируйтесь
              AD

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

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

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

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

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

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

              Следите за нами в социальных сетях