AR
Dec. 25, 2020, 3:27 p.m.

База данных в QTableView

база данных, QTableView

Всем привет! Имеется база данных, привязана к Qtableview, все отображается правильно, но некоторые столбцы необходимо показывать измененными (применить к ним функцию), но в самой бд при этом не трогать, изменённые показать только в qtableview.
Как это сделать?
Модель привязана стандартно

  1. Database *db;
  2. QSqlRelationalTableModel *model;
  3. ...
  4. db = new DataBase() ;
  5. db->connectToDataBase() ;
  6. ...
  7. this->setupModel(...) ;
  8. ui->tableView->setModel(model) ;
  9.  

Изменения эти нужны по кнопке

  1. void myf::push()
  2.  
  3. {
  4.  
  5. for(int i=0; i<model->rowCount() ;i++)
  6.  
  7. {
  8.  
  9. QModelIndex myInd = model->index(i, 8, QModelIndex()) ;
  10.  
  11. QVariant MyDat = model->data(myInd, Qt::EditRole) ;
  12.  
  13. model->setData (..)
  14.  
  15. }
  16.  
  17. }

Но setData вносит изменения и в БД
Как избежать этого и изменить исключительно таблицу?

3

Do you like it? Share on social networks!

2
ИП
  • Dec. 25, 2020, 4:25 p.m.

Необходимо сделать наследование от класса QSqlRelationalTableModel, в данном классе переопределить метод data()

    Михаиллл
    • Dec. 25, 2020, 5:59 p.m.

    Нужно переопределить метод получения данных, толи data, толи getData и там мделать обработку нужного столбца

      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