Feb. 15, 2020, 11:31 a.m.

Как обрабатывать ошибки при использовании 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>> " "

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.
6

QSqlError после select

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

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

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

IP
#include <QSqlError>
#include <QSqlQuery>
...

if (!model->select())
    {
        qDebug() << model->lastError().text();
        qDebug() << model->query().lastQuery();
    }
  • Feb. 19, 2020, 11:58 a.m.

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

  • Feb. 19, 2020, 4:14 p.m.

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

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

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

IP

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

Comments

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

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

DK
April 1, 2020, 8:03 a.m.
Dmitry Kozhinov

C++ - Test 001. The first program and data types

  • Result:40points,
  • Rating points-8
A
March 30, 2020, 12:47 p.m.
Anna

C++ - Test 001. The first program and data types

  • Result:60points,
  • Rating points-1
A
March 29, 2020, 12:14 p.m.
Alexanderv66

C++ - Тест 003. Условия и циклы

  • Result:71points,
  • Rating points1
Last comments
April 3, 2020, 8:06 a.m.
Konstantin Grudnitskiy

Я надеюсь вы уже разобрались в чем дело, но если вдруг нет, то проблема состоит в том, что вы пытаетесь запустить программу из интерпретатора питона. Файл main.py это уже готова…
April 3, 2020, 6:18 a.m.
Konstantin Grudnitskiy

>>> text = 'hello world'>>> ' '.join(word for word in text.split()[:-1])'hello'>>> def remove_last_word(text):... return text and ' '.join(word for word in text.s…
March 27, 2020, 2:40 p.m.
Evgenij Legotskoj

Добрый день. В конце пятой статьи скачать можете.
March 27, 2020, 2:28 p.m.
mkdir _

Здравствуйте, а можно, пожалуйста, ссылку на целые исходники, если есть?
March 27, 2020, 4:36 a.m.
Evgenij Legotskoj

Скорее всего также, как и для установки всех остальных переменых в CMake, через использование set
Now discuss on the forum
April 3, 2020, 12:53 p.m.
BlinCT

Само собою на компе этого незаметно.
April 3, 2020, 8:48 a.m.
Intruder

Евгений, добрый день. Спасибо!
s
April 3, 2020, 7:52 a.m.
solmik

да вроде много чего установленно, если неправильный путь указать то же самое, пробовал запустить видео через плей лист (по примерам из док)и из него назад путь взять, не получилось
April 3, 2020, 5:50 a.m.
Jurij-V

Спасибо ! Поковырявшись и посмотрев интерфейс QSvgRender и т.д. понимаю что похоже нужно будет лезть в реализацию ::render(..). Кто может подсказать как и где выкачать актуальные исходники…
April 2, 2020, 2:46 a.m.
Evgenij Legotskoj

Я думаю, что это где-то описано, но в такой глубине документации и максимум в самых базовых вещах, то есть отдельно в классах этого не пишут, просто потому, что придётся писать для каждого класс…
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB