Реклама

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;

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

"(:id_)"


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

:id_

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

Screenshot_4.png

Вообще, вы делаете всё правильно. Но, возможно, это придурь парсера этих 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.

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

Screenshot_5.png

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

 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)");

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

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

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

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

dialog->getFirstName()

QString, getSholarship - bool, getBirthdate- QDate.

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

indexes.at(0).row()

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

indexes.at(0).data()

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

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

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

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

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

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

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

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

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

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

Реклама

Ответы

Только авторизованные пользователи могут отвечать на форуме.
Пожалуйста, Авторизуйтесь или Зарегистрируйтесь
Последние комментарии
  • EVILEG
  • 23 мая 2017 г. 12:26

Qt/C++ - Урок 005. QSqlRelationalTableModel - Работаем со связными таблицами

В классе DataBase указывается путь к базе данных. В данном случае C:/example/ и т.д. Так вот, у вас есть каталог example ?

  • EVILEG
  • 23 мая 2017 г. 12:19

Qt/C++ - Урок 029. Изображение в базе данных в Qt – Сохранение и Восстановление

Нет. не верно. Ошибка вот в этой строке: QPixmap inixmap = fileName; // Сохраняем его в изображение объекта QPixmap; Выше я показывал, как что нужно путь передавать в качестве аргумент...

Qt/C++ - Урок 029. Изображение в базе данных в Qt – Сохранение и Восстановление

QString fileName = QFileDialog::getOpenFileName(this, tr("Open File"), "/home", tr("Images (*.png *.xpm *.jpg)")); QPixmap inixmap = fileName; // Сохраняем его в и...

Qt/C++ - Урок 005. QSqlRelationalTableModel - Работаем со связными таблицами

https://www.dropbox.com/sh/vhxcx0iyq0j4578/AACwgWPnZwNqGBndKESiXfFqa?dl=0

  • tetta
  • 22 мая 2017 г. 1:32

Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP

Как сделать так, что бы только когда верхнюю полосу зажимаешь, то перетаскивалось окно и что бы оно оставалось на месте?

Сейчас обсуждают на форуме
  • tetta
  • 23 мая 2017 г. 17:59

Создание кнопки "new", "save" и "open". MDI. toolBar

void MainWindow::open(){ QString openFile = QFileDialog::getOpenFileName(this, tr("Open File"), "C:/", ...

Проверка наличия записи в БД при выполнении запроса

Код форм про которые говорил прикрепил. regrdit форма в которой отображается информация отбираемая из базы. editobject форма для редактирования

  • Arrow
  • 23 мая 2017 г. 13:41

qmake

Странно по сообщениям выдает, что у меня компилирутся 32 bit версия (x86 build). Компилятор опознан правильно и в ABI сам определилил x86-windows-msys-pre-64bit и исполняемый файл создае...

WinApi CBTProc

Да всех активных, тоесть через CBT.