Юрий
ЮрийАқп. 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, 4:14 Т.Қ.

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

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

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

            ИП
            • Ақп. 19, 2020, 11:55 Т.Қ.

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

              Пікірлер

              Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
              Кіріңіз немесе Тіркеліңіз
              Г

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

              • Нәтиже:66ұпай,
              • Бағалау ұпайлары-1
              t

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

              • Нәтиже:33ұпай,
              • Бағалау ұпайлары-10
              t

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

              • Нәтиже:52ұпай,
              • Бағалау ұпайлары-4
              Соңғы пікірлер
              G
              GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
              Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
              d
              dblas5Шілде 5, 2024, 11:02 Т.Ж.
              QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
              k
              kmssrАқп. 8, 2024, 6:43 Т.Қ.
              Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
              АК
              Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
              Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
              Енді форумда талқылаңыз
              Evgenii Legotckoi
              Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
              добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
              F
              FynjyШілде 22, 2024, 4:15 Т.Ж.
              при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
              BlinCT
              BlinCTМаусым 25, 2024, 1 Т.Ж.
              Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
              BlinCT
              BlinCTМамыр 5, 2024, 5:46 Т.Ж.
              Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
              Evgenii Legotckoi
              Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
              Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

              Бізді әлеуметтік желілерде бақылаңыз