Виталий Антипов
Виталий Антипов24 декабря 2017 г. 17:50

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

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

P.S. Таблицы (самодельные ListView) заполняю через модели и роли, странички с данными объектов посредством вашего Data Mapper через mapper.addMapping() (почему-то мне кажется это очень удобным).
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

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

1
Виталий Антипов
  • 24 декабря 2017 г. 21:32
  • Ответ был помечен как решение.

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

    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 изменяемой записи
В общем все по аналогии с созданием новой записи из урока.

    Комментарии

    Только авторизованные пользователи могут публиковать комментарии.
    Пожалуйста, авторизуйтесь или зарегистрируйтесь
    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 Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.

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