SQL take a value
Привет. Не получается забрать значение с query.
Вот такой метод отрабатывает верно, то есть, если у меня поле weight = 3, то 3 и вернет
int ReportDataBase::getWeight(const int reportID) const { int weight = 0; QSqlQuery query(db); QString queryString = QString("SELECT weight FROM reports WHERE id=")+QString::number(reportID); query.prepare(queryString); query.exec(queryString); if(query.isActive()) { if(query.next()) { const QSqlRecord record = query.record(); weight = query.value(record.indexOf("weight")).toInt(); } } return weight; }
но вот аналогичный метод, уже пишет ошибку
QSqlQuery::value: not positioned on a valid record
в строке
query.value(record.indexOf("weight")).toInt()
int ReportDataBase::getLowerWeight() const { int weight = 0; QSqlQuery query(db); QString queryString = QString("SELECT MAX(weight) FROM reports"); query.prepare(queryString); query.exec(queryString); if(query.isActive()) { if(query.next()) { const QSqlRecord record = query.record(); weight = query.value(record.indexOf("weight")).toInt(); } } return weight; }
при чем, в отладчике я вижу нужное мне значение, вот оно
но всё-равно ставит weight = 0, как так-то? код же аналогичный! скрипт рабочий! я в SQLite проверял этот запрос.
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
B
- Bogdannn
- March 27, 2024, 7:15 p.m.
C++ - Test 001. The first program and data types
- Result:46points,
- Rating points-6
Last comments
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоFeb. 5, 2024, 1:50 a.m.
EVADec. 25, 2023, 10:30 a.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
Как получить в массив значения из связанной модели? Спасибо, разобрался:))
AC
QML Обнулить значения SpinBox Доброго времени суток, не могу разобраться с обнулением значение SpinBox находящего в делегате. import QtQuickimport QtQuick.ControlsWindow { width: 640 height: 480 visible: tr…
Alexandru CodreanuJan. 19, 2024, 11:57 a.m.
BlinCTDec. 27, 2023, 8:57 a.m.
ДмитрийJan. 10, 2024, 4:18 a.m.
Evgenii LegotckoiDec. 12, 2023, 6:48 a.m.
Добрый день
Есть мысль, что там нужно имя задать для результата. Скорее всего возвращается результат выполнения с именем, отличным от weight
Напишите так
огромное вам спасибо! я вчера сидел с этой фигней часов до 11 вечера и потом в отлачике нашел ошибку, ну думаю, делов на 5 минут, решил лечь спать и проснуться сегодня пораньше и доделать успеть. В итоге, с 7 утра уже часов 5, как слепой котенок наугад, идеи все кончились и гугл тоже) А так работает! Еще раз спасибо!
Внутренние функции SQL типо max, min генерируют имена для колонок наподобие max_weight.
Уверен, что если написать так, то тоже заработает
Ваш запрос генерирует новую таблицу, а не просто забирает пачку записей из существующих, поэтому нужно либо явно задавать имя колонки, либо понимать логику генерирования имён новых колонок в зависимости от внутренних функций SQL
спасибо за пояснения!