Privacy policyContactsAbout siteOpinionsGitHubDonate
© EVILEG 2015-2018
Recommend hosting
TIMEWEB
Jan. 2, 2019, 10:07 a.m.

Как получить данные из QSqlQuery при запросе SELECT

qt, SELECT, QSqlQuery

Здравствуйте. Делаю запрос в базу данных:

    QSqlQuery query;
    query.prepare("SELECT "
                  "\"NumberID\" ,"
                  "\"Name\" ,"
                  "\"Comments\" ,"
                  "\"Resume\""
              " FROM " + NameTableDB +
             " WHERE \"NumberID\" = 52" 
              ";");

    if (!query.exec()) {qDebug()<<"не получило данные";}
    else
    {
        qDebug()<<"получило данные";
        int IdResume = query.value(0).toInt();
        QString NameResume = query.value(1).toString();
        QString ComentResume = query.value(2).toString();
        QString Resume = query.value(3).toString();
        qDebug()<<"Id"<<IdResume;
        qDebug()<<"Name"<<NameResume;
        qDebug()<<"coment"<<ComentResume;
        qDebug()<<"resume"<<Resume;
    }

дебаг выдает: получило данные QSqlQuery::value: not positioned on a valid record QSqlQuery::value: not positioned on a valid record QSqlQuery::value: not positioned on a valid record QSqlQuery::value: not positioned on a valid record Id 0 Name "" coment "" resume "" Скажите пожалуйста, как мне получить эти данные?

4

так работает

        query.first();
        QString NameResume = query.value(0).toString();
        QString ComentResume = query.value(1).toString();
        QString Resume = query.value(2).toString();
        qDebug()<<"Name"<<NameResume;
        qDebug()<<"coment"<<ComentResume;
        qDebug()<<"resume"<<Resume;
0
query.next();

Первым оператором в else добавьте.

0
R

просто потрібно викликати query.next() короткий приклад з коду

        n_query = QString("SELECT item_type, "
                          " FROM category WHERE item_id = %1")
                .arg(json["ic"].toInt()));

    }

    if (!m_query.exec(n_query))
    {
        qDebug() << Q_FUNC_INFO << n_query;
        qDebug() << m_query.lastError();
    }


    QSqlRecord rec = m_query.record();
    while (m_query.next()) {
        QJsonObject arr;
        arr.insert("it_type", QJsonValue(m_query.value(rec.indexOf("item_type")).toBool()));
        }
0

Извините что побеспокоил. Как уже говорил query.first(); все поправило. Спасибо всем за участие.

0

Comments

Only authorized users can post comments.
Please, Log in or Sign up
v
Jan. 17, 2019, 11:51 a.m.
vitalir12

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:20points,
  • Rating points-10
v
Jan. 17, 2019, 11:49 a.m.
vitalir12

C++ - Test 002. Constants

  • Result:50points,
  • Rating points-4
v
Jan. 17, 2019, 11:13 a.m.
vitalir12

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

  • Result:28points,
  • Rating points-10
Last comments
I
Jan. 16, 2019, 8:06 a.m.
IscanderChe

Заработало. Забыл model->select(); вписать.
I
Jan. 16, 2019, 8:02 a.m.
IscanderChe

Всё равно пусто, хотя строка с данными в базу добавляется.
Jan. 16, 2019, 7:51 a.m.
Евгений Легоцкой

потому, что нужно сохранять информацию для всех остальных ролей и столбцов через вызов переопределённого метода. Да к тому же вы ещё и зациклили вызов метода data. QVariant MySqlTableModel:...
I
Jan. 16, 2019, 7:43 a.m.
IscanderChe

Сделал вот так. В tableView ничего нет, кроме заголовка. QVariant MySqlTableModel::data(const QModelIndex &index, int role) const{ if (role == Qt::DisplayRole) { QTime ...
Now discuss on the forum
Jan. 17, 2019, 1:40 p.m.
Михаиллл

Спасибо, заработало.Учту с переменными.
Jan. 17, 2019, 12:01 p.m.
Алексей Внуков

у меня просто есть отдельное поле с чекбоксамими какие колонки нужно отображать CheckBox { id: checkBox text: qsTr("some text") checked: true onC...
Jan. 15, 2019, 4:53 p.m.
Михаиллл

Спасибо, заработало.Но выдало обычный текст без форатирования HTML.Придется искать дальше
Jan. 15, 2019, 12:52 p.m.
BlinCT

Я же вам выше написал CLion умеет работать с ремоут машинами. И Qt так же собирает.
Join us in social networks

For registered users on the site there is a minimum amount of advertising