ДК
Джон Кофи23 апреля 2020 г. 15:11

SQL take a value

SQLite

Привет. Не получается забрать значение с 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 проверял этот запрос.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

5
Evgenii Legotckoi
  • 23 апреля 2020 г. 15:21
  • Ответ был помечен как решение.

Добрый день

Есть мысль, что там нужно имя задать для результата. Скорее всего возвращается результат выполнения с именем, отличным от weight

Напишите так

int ReportDataBase::getLowerWeight() const
{
    int weight = 0;
    QSqlQuery query(db);
    QString queryString = QString("SELECT MAX(weight) AS weight_result 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_result")).toInt();
        }
    }
    return weight;
}
    ДК
    • 23 апреля 2020 г. 15:27

    огромное вам спасибо! я вчера сидел с этой фигней часов до 11 вечера и потом в отлачике нашел ошибку, ну думаю, делов на 5 минут, решил лечь спать и проснуться сегодня пораньше и доделать успеть. В итоге, с 7 утра уже часов 5, как слепой котенок наугад, идеи все кончились и гугл тоже) А так работает! Еще раз спасибо!

      Evgenii Legotckoi
      • 23 апреля 2020 г. 15:31

      Внутренние функции SQL типо max, min генерируют имена для колонок наподобие max_weight.
      Уверен, что если написать так, то тоже заработает

      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("max_weight")).toInt();
              }
          }
          return weight;
      }
      

      Ваш запрос генерирует новую таблицу, а не просто забирает пачку записей из существующих, поэтому нужно либо явно задавать имя колонки, либо понимать логику генерирования имён новых колонок в зависимости от внутренних функций SQL

        ДК
        • 23 апреля 2020 г. 15:37

        спасибо за пояснения!

          ИП
          • 23 апреля 2020 г. 15:52
          int ReportDataBase::getLowerWeight() const
          {
              //int weight = 0;
              QSqlQuery query(db);
              QString queryString = QString("SELECT MAX(weight) AS max_weight FROM reports");
              //query.prepare(queryString);//подготовленный запрос здесь не нужен
              //query.exec(queryString);
              if(query.exec(queryString))
              {
                  if(query.first()) //если в результате только одна строка
                  {
                      //const QSqlRecord record = query.record(); 
                      return query.value("max_weight").toInt();
                  }
                  else 
                  {}//здесь можно обработать ситуацию когда таблица пустая или запрос сработал и вернул пустую строку
              }
              else
              {} //здесь можно обработать ошибку запроса
              return -1;
          }
          

            Комментарии

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

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

            • Результат:84баллов,
            • Очки рейтинга4
            Ua

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

            • Результат:42баллов,
            • Очки рейтинга-8
            ОК

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

            • Результат:47баллов,
            • Очки рейтинга-6
            Последние комментарии
            ИМ
            Игорь Максимов22 ноября 2024 г. 21:51
            Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
            Evgenii Legotckoi
            Evgenii Legotckoi31 октября 2024 г. 23:37
            Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
            A
            ALO1ZE19 октября 2024 г. 17:19
            Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
            ИМ
            Игорь Максимов5 октября 2024 г. 16:51
            Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
            d
            dblas55 июля 2024 г. 20:02
            QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
            Сейчас обсуждают на форуме
            f
            firstlunoxod15 февраля 2025 г. 13:46
            Рисование на QGraphicsScene при зажатой кнопке мыши Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
            Дмитрий
            Дмитрий3 февраля 2025 г. 16:24
            Создание deb-пакета. Как создать ярлык на рабочем столе после установки собственного deb-пакета? Всем привет. Сделал свой deb-пакет с программой. Всё устанавливается и работает. Ставлю по пути /usr/bin/my_application. Как для пользователя при установке пакета сразу создать ярлык на раб…
            NW
            Nayo Wai30 января 2025 г. 19:22
            не запускается компьютер!!! Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
            n
            nkly3 января 2025 г. 12:52
            Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
            M
            Marsel17 августа 2023 г. 0:26
            OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

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