Виталий Антипов
Dec. 24, 2017, 5:50 p.m.

Изменение данных в таблицах базы

Добрый день! Сейчас работаю с sqlite базой данных на основе ваших уроков. Выборка данных и их представление, удаление и создание новых работают без проблем и все красиво. Но как быть с редактированием данных таблиц базы? В ваших уроках этот момент почему-то опущен. Подскажите, в какую сторону копать?

P.S. Таблицы (самодельные ListView) заполняю через модели и роли, странички с данными объектов посредством вашего Data Mapper через mapper.addMapping() (почему-то мне кажется это очень удобным).
1
The question is asked by the articleQML - Lesson 016. SQLite database and the working with it in QML Qt

Do you like it? Share on social networks!

1
Виталий Антипов
  • Dec. 24, 2017, 9:32 p.m.
  • The answer was marked as a solution.

Извиняюсь за заданный вопрос. Сам разобрался. Создал следующие методы:

    bool editTableBaza(const QVariantList &data);
    bool editTableBaza(const QString &Baza_id, const QString &Bazakks);
Их конструкторы:
bool DataBase::editTableBaza(const QVariantList &data)
{    
    QSqlQuery querys;    
    querys.prepare("update Baza set KKS = :Bazakks where Baza.id = :Baza_id");
    querys.bindValue(":Baza_id", data[0].toString());
    querys.bindValue(":Bazakks", data[1].toString());
    qDebug()<<data[0].toString();
    if(!querys.exec()){
        qDebug() << "error update Baza ";
        qDebug() << querys.lastError().text();
        return false;
    } else {
        return true;
    }
    return false;
}

bool DataBase::editTableBaza(const QString &Baza_id, const QString &Bazakks)
{
    QVariantList data;
    data.append(Baza_id);
    data.append(Bazakks);
    if(editTableBaza(data))
        return true;
    else
        return false;
}
а в QML вызываем:
database.editTableBaza(stackView.baza_id, tf_kks.text) //stackView.baza_id содержит id изменяемой записи
В общем все по аналогии с созданием новой записи из урока.

    Comments

    Only authorized users can post comments.
    Please, Log in or Sign up
    • Last comments
    • AK
      April 1, 2025, 11:41 a.m.
      Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
    • Evgenii Legotckoi
      March 9, 2025, 9:02 p.m.
      К сожалению, я этого подсказать не могу, поскольку у меня нет необходимости в обходе блокировок и т.д. Поэтому я и не задавался решением этой проблемы. Ну выглядит так, что вам действитель…
    • VP
      March 9, 2025, 4:14 p.m.
      Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
    • ИМ
      Nov. 22, 2024, 9:51 p.m.
      Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    • Evgenii Legotckoi
      Oct. 31, 2024, 11:37 p.m.
      Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup