i
Aug. 25, 2017, 3:05 a.m.
QTableView connected with QSqlTableModel flickers (scrolls to the bottom and returns)
qt, qsql, QSqlDataBase, QSqlTableModel, QTableView
Hello guys I have a problem using table view. I have a
tableview connected with a QSqlTableModel. On its 2nd column I want to
have check state to control the row's Status (active/inactive) but when I
try to push the check box QTableView scrolls to the bottom and returns
to it's previous position. Is there any solution?
bool ProjectsModel::setData(const QModelIndex &index, const QVariant &value, int role) { if(index.column() == STATUS_INDEX) { QSqlRecord rec = this->record(index.row()); QString qrstr; qrstr = (rec.field(index.column()).value().toInt() == 1) ? "update " + tableName() + " set Status=0 where BRACE_ID=" : "update " + tableName() + " set Status=1 where BRACE_ID="; qrstr += QString().setNum(index.row()+1); braceDatabase->exec(qrstr.toUtf8().constData()); return true; } return false; } void DataBase::updateTablesSlot() { if(projectsModel) projectsModel->select(); if(attributesModel) attributesModel->select(); if(targetsModel) targetsModel->select(); } void DataBase::exec(const std::string &querystr) { QSqlQuery qr(db); qr.exec(querystr.c_str()); //qDebug() <<"Command :" << querystr.c_str() << "-> "<< query->lastError().text(); updateTables(); }
2
252
Do you like it? Share on social networks!
- Last comments
- AKApril 1, 2025, 11:41 a.m.Добрый день. В данный момент работаю над проектом, где необходимо выводить звук из программы в определенное аудиоустройство (колонки, наушники, виртуальный кабель и т.д). Пишу на Qt5.12.12 поско…
- VPMarch 9, 2025, 4:14 p.m.Здравствуйте! Я устанавливал Qt6 из исходников а также Qt Creator по отдельности. Все компоненты, связанные с разработкой для Android, установлены. Кроме одного... Когда пытаюсь скомпилиров…
- ИМNov. 22, 2024, 9:51 p.m.Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
- Now discuss on the forum
- fFeb. 15, 2025, 1:46 p.m.Подскажите, пожалуйста! Как данный класс можно дополнить, чтобы созданные объекты можно было перемещать мышкой по сцене?
- Не запускается компьютер (точнее работает блок , но сам монитор вообще жесть)В общем я ничего с интернета не скачивала в последнее время. На компе никаких левых пр…
- Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
- Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Hello!
I think you need to use QItemDelegate for this (or same claas which was inherited from this class). Or You can use QTableWidget.
You can research article with checkboxes in QTableWidget .
May be it will be usefull for You.
And may be you need use for scroll method scrollTo()
Hello my friend and thank you for the help unfortunately I can't use QTableWidget for performance reasons, I must load big databases from csv files. If I try the second solution with the scroll It will have a disturbing effect the table will hop up and down every time the user presses the check state.
Christos,
Greeting from Thessaloniki, Greece
Ok. May be You need to use custom ItemDelegate for this.
And set delegate
Best Regards from Prague.
I changed my code to this one but the check state on click didn't change :(
I am not sure, but problem of this solution may be in Qt::Checked and Qt::Unchecked.
Because this enum has 3 states
That's the point I want the status of the row to be Active/Inactive PartiallyChecked option is useless for me. Do you refer that I had an error on this line ?
I am not sure, but may be you can try to check the following code in this row:
Hmm you may be right I will check it EVILEG and I will report later thank you