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 р. 02: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 р. 04:17

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

          Ruslan Polupan
          • 19 травня 2017 р. 06: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 р. 02: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 р. 06:04

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

                          Evgenii Legotckoi
                          • 21 травня 2017 р. 06:20
                          • Відповідь була позначена як рішення.

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

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

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

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

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

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

                            R
                            • 21 травня 2017 р. 06:38

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

                              Коментарі

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

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

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

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

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

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

                              • Результат:20бали,
                              • Рейтинг балів-10
                              Останні коментарі
                              ИМ
                              Игорь Максимов22 листопада 2024 р. 22:51
                              Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                              Evgenii Legotckoi
                              Evgenii Legotckoi01 листопада 2024 р. 00:37
                              Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                              A
                              ALO1ZE19 жовтня 2024 р. 18:19
                              Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                              ИМ
                              Игорь Максимов05 жовтня 2024 р. 17:51
                              Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                              d
                              dblas505 липня 2024 р. 21:02
                              QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                              Тепер обговоріть на форумі
                              Evgenii Legotckoi
                              Evgenii Legotckoi25 червня 2024 р. 01:11
                              добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                              t
                              tonypeachey115 листопада 2024 р. 17:04
                              google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                              NSProject
                              NSProject04 червня 2022 р. 13:49
                              Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                              9
                              9Anonim25 жовтня 2024 р. 19:10
                              Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                              Слідкуйте за нами в соціальних мережах