R
Rus6lan18 мая 2017 г. 14:54

UPDATE query in QSql

Запрос не выполняется. Ошибок нет. Как только не пробовал

QModelIndexList indexes = ui->tableView->selectionModel()->selectedRows();
    QVariantList data;
    data.append(dialog->getFirstName());
    data.append(dialog->getLastName());
    data.append(dialog->getPatronymic());
    if(dialog->getScholarship()) data.append("true");
    else data.append("false");
    data.append(dialog->getBirthdate());
QSqlQuery query;
    QString das = data[0].toString();
    query.prepare("UPDATE " TABLE " SET FirstName=(:FirstName) WHERE id=:id_");
    query.bindValue("(:FirstName)", das);
    query.bindValue("(:id_)", indexes[0].row());
        if(!query.exec()){
                qDebug() << "error update" << TABLE;
                qDebug() << query.lastError().text();
                return false;
            } else {
                dialog->close();
                sqlModel->select();
                return true;
            }
            return false;
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

14
D
  • 18 мая 2017 г. 16:34

Я конечно не профессионал, но вы биндите

"(:id_)"


Когда в запросе пишите

:id_
    R
    • 18 мая 2017 г. 16:46

    Ну да, но я по-разному пробовал, это видимо одна из вариаций была. Никак не работает, ни со скобками ни без. Вообще по-моему запрос не формируется нормально. Вот скрин.

      Evgenii Legotckoi
      • 19 мая 2017 г. 2:37

      Вообще, вы делаете всё правильно. Но, возможно, это придурь парсера этих SQL запросов в QSqlQuery. Попробуйте записать запрос с биндами так:

      query.prepare("UPDATE " TABLE " SET FirstName = :firstname WHERE id = :ID;");
      query.bindValue(":firstname", das);
      query.bindValue(":ID", indexes[0].row());
      query.exec();

      У меня некоторые запросы не работали без наличия точки с запятой в конце, либо пока я не подготавливал запрос сначала в QString, а потом уже этот подготовленный QString отправлял в QSqlQuery.

        R
        • 19 мая 2017 г. 4:17

        Не работает. Я главное не очень понимаю, как отслеживать, где именно произошла ошибка, справа в дебаге в поле executedQuery вопросы вместе id, firstname. Значит ли это что он не связал значения? На скриншоте я уместил еще и весь код. мб там что-то не так?

          Ruslan Polupan
          • 19 мая 2017 г. 6:24

          Только что сталкивался с похожей ситуацией.

           q.prepare("INSERT INTO stamps (range, number, status) VALUES (:range, :number, 1)");
          Отказывалось работать.
          Зашел в визуальный редактор БД добавил запись получил код запроса.
          В результате код ниже работает.
          
           q.prepare("INSERT INTO `cso`.`stamps` (`range`,`number`, `status`) VALUES (:range, :number, 1)");
            R
            • 19 мая 2017 г. 13:29

            А что этот код делает? Ну у меня insert работает нормально

              Ruslan Polupan
              • 19 мая 2017 г. 14:57

              Я к тому что сделай запрос к БД на прямую, потом скопирй в Qt. Парсинг запросов меня в тупик часто ставит.

                R
                • 19 мая 2017 г. 16:36

                Напрямую, это в клиенте СУБД? У меня это Sqlitestudio.

                  Evgenii Legotckoi
                  • 20 мая 2017 г. 2:09

                  А что возвращает метод getFirstName()? Объект какого типа?

                  dialog->getFirstName()
                    R
                    • 20 мая 2017 г. 12:12

                    QString, getSholarship - bool, getBirthdate- QDate.

                      Evgenii Legotckoi
                      • 20 мая 2017 г. 23:42

                      Тогда, разве только расставить апострофы в запросе для экранирования. Как сделано в одном из сообщений выше. Ну и переписать обращение к индексу QModelIndexList.

                      indexes.at(0).row()

                      Кстати, а вы уверены, что когда забираете QModelIndexList, и обращаетесь к первому индексу, то номер его строки соответствует ID? Поскольку row() возвращает номер строки в таблице, к которой вы выделили эту строку. И если у Вас сделано автоинкрементирование ID, и база уже многократно подвергалась изменениям, то скорее всего row() будет возвращать номер, отличный от ID, записи. В данном случае нужно забирать данные, через метод data()

                      indexes.at(0).data()

                      Заметьте, что в данном случае QModelIndex, к которому обращаетесь должен обязательно соответствовать той колонке, в которой находится ID.

                        R
                        • 21 мая 2017 г. 6:04

                        А чем at() лучше []? То есть я должен указать, число означающее в какой колонке у меня в таблице нужно поле. Я правильно понял?

                          Evgenii Legotckoi
                          • 21 мая 2017 г. 6:20
                          • Ответ был помечен как решение.

                          В принципе, разницы нет между at() и [], оператор [] выполняет тот же функционал, но обычно используют at().

                          Что касается поля. То нужно взять по строке индекс с той колонкой, где находится ID записи. Эту колонку можно сделать скрытой, чтобы она глаза не мозолила в таблице.

                          Тогда, допустим что ID находится в колонке под номером 0. В результате получается, что берём нужный ID индекс так.

                          model->index(indexes.at(0).row(), 0).data(); 

                          То есть, зная, из какой строки дёргать данные, берём из модели данных индекс, который содержит ID, по номеру колонки для ID и номер строки из выделения.

                          А после этого уже попытаться выполнить запрос. Возможно, что ID передаётся неправильный, поэтому ничего и не происходит, поскольку обновлять нечего, так как не существует запись с таким ID.

                            R
                            • 21 мая 2017 г. 6:38

                            Да , я спрятал id, потому что tableview итак нумерует. Спасибо, буду у компьютера попробую.

                              Комментарии

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

                              C++ - Тест 004. Указатели, Массивы и Циклы

                              • Результат:50баллов,
                              • Очки рейтинга-4
                              m
                              • molni99
                              • 26 октября 2024 г. 1:37

                              C++ - Тест 004. Указатели, Массивы и Циклы

                              • Результат:80баллов,
                              • Очки рейтинга4
                              m
                              • molni99
                              • 26 октября 2024 г. 1:29

                              C++ - Тест 004. Указатели, Массивы и Циклы

                              • Результат:20баллов,
                              • Очки рейтинга-10
                              Последние комментарии
                              i
                              innorwall11 ноября 2024 г. 22:12
                              Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
                              i
                              innorwall11 ноября 2024 г. 18:23
                              QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
                              i
                              innorwall11 ноября 2024 г. 15:50
                              Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
                              i
                              innorwall11 ноября 2024 г. 14:19
                              Алгоритм сортировки кучей The role of raloxifene in preventing breast cancer priligy precio
                              i
                              innorwall11 ноября 2024 г. 13:55
                              PyQt5 - Урок 006. Работа с QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
                              Сейчас обсуждают на форуме
                              i
                              innorwall11 ноября 2024 г. 20:56
                              добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
                              i
                              innorwall11 ноября 2024 г. 10:55
                              Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
                              9
                              9Anonim25 октября 2024 г. 9:10
                              Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
                              ИМ
                              Игорь Максимов3 октября 2024 г. 4:05
                              Реализация навигации по разделам Спасибо Евгений!

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