Russian Qt Forum
Март 29, 2024, 13:04
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Вопросы новичков
>
Добавление и удаление строк из TableView.
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Добавление и удаление строк из TableView. (Прочитано 7846 раз)
diagnosefiz
Гость
Добавление и удаление строк из TableView.
«
:
Июнь 01, 2017, 11:43 »
Удаляю строку из QTableView с помощью запроса для бд postgres, но она не удаляется из таблицы. О том что она удалилась, мы узнаем только по следующему открытию талицы. Как сделать обновление вида таблицы по нажатию кнопки "'Delete"? Слот на нажатие клавиши "Delete":
Код:
void DialogNewColumn::on_pushButton_2_clicked()
{
QSqlQuery query;
QString table = tables->currentText();
QString nameColumn = ui->tableView->model()->data(ui->tableView->currentIndex()).toString();
qDebug() << ui->tableView->model()->data(ui->tableView->currentIndex());
QString str = "ALTER TABLE \"" + table + "\" DROP COLUMN \"" + nameColumn + "\" ";;
query.exec(str);
}
Записан
gil9red
Administrator
Джедай : наставник для всех
Offline
Сообщений: 1805
Re: Добавление и удаление строк из TableView.
«
Ответ #1 :
Июнь 01, 2017, 12:08 »
А какая модель у таблицы?
Записан
https://github.com/gil9red
https://ru.stackoverflow.com/users/201445/gil9red
diagnosefiz
Гость
Re: Добавление и удаление строк из TableView.
«
Ответ #2 :
Июнь 01, 2017, 12:14 »
Цитата: gil9red от Июнь 01, 2017, 12:08
А какая модель у таблицы?
QStandardItemModel
Записан
gil9red
Administrator
Джедай : наставник для всех
Offline
Сообщений: 1805
Re: Добавление и удаление строк из TableView.
«
Ответ #3 :
Июнь 01, 2017, 12:46 »
Понятно, а открытие таблицы это новое заполнение QStandardItemModel из запроса к базе? Если данных мало, то можно после удаления у модели вручную удалить. Из ui->tableView->currentIndex() можно узнать индекс столбца
Я спрашивал про модель, потому что есть специальные модели для работы с базами, например
QSqlTableModel
Записан
https://github.com/gil9red
https://ru.stackoverflow.com/users/201445/gil9red
diagnosefiz
Гость
Re: Добавление и удаление строк из TableView.
«
Ответ #4 :
Июнь 01, 2017, 13:04 »
Цитата: gil9red от Июнь 01, 2017, 12:46
Понятно, а открытие таблицы это новое заполнение QStandardItemModel из запроса к базе? Если данных мало, то можно после удаления у модели вручную удалить. Из ui->tableView->currentIndex() можно узнать индекс столбца
Я спрашивал про модель, потому что есть специальные модели для работы с базами, например
QSqlTableModel
Это мой первый проект и почти все запросы реализованы на перегрузке модели. Т.е. каждый новый запрос - это перезагрузка всей модели.((понимаю, что криво сделано. Есть ли способ догружать данные в существующую модель?
Записан
gil9red
Administrator
Джедай : наставник для всех
Offline
Сообщений: 1805
Re: Добавление и удаление строк из TableView.
«
Ответ #5 :
Июнь 01, 2017, 13:16 »
Цитата: diagnosefiz от Июнь 01, 2017, 13:04
Есть ли способ догружать данные в существующую модель?
Конечно, работайте с QStandardItemModel. Добавляете в модель новые данные, она сообщит таблице о них и таблица обновится
Записан
https://github.com/gil9red
https://ru.stackoverflow.com/users/201445/gil9red
diagnosefiz
Гость
Re: Добавление и удаление строк из TableView.
«
Ответ #6 :
Июнь 01, 2017, 13:44 »
Цитата: gil9red от Июнь 01, 2017, 13:16
Цитата: diagnosefiz от Июнь 01, 2017, 13:04
Есть ли способ догружать данные в существующую модель?
Конечно, работайте с QStandardItemModel. Добавляете в модель новые данные, она сообщит таблице о них и таблица обновится
В эту ячейку нужно поместить combobox и чтобы он появлялся только когда появляется новая пустая строка для ввода данных. я читала что это можно реализовать с помощью делегатов на combobox, но так и не разобралась. Есть ли другой способ?
Записан
diagnosefiz
Гость
Re: Добавление и удаление строк из TableView.
«
Ответ #7 :
Июнь 01, 2017, 14:27 »
Цитата: gil9red от Июнь 01, 2017, 12:46
Понятно, а открытие таблицы это новое заполнение QStandardItemModel из запроса к базе? Если данных мало, то можно после удаления у модели вручную удалить. Из ui->tableView->currentIndex() можно узнать индекс столбца
Я спрашивал про модель, потому что есть специальные модели для работы с базами, например
QSqlTableModel
Код:
QModelIndex string = ui->tableView->currentIndex().row();
model->removeRows(string, 1);
Верно ли я вас поняла?
Записан
gil9red
Administrator
Джедай : наставник для всех
Offline
Сообщений: 1805
Re: Добавление и удаление строк из TableView.
«
Ответ #8 :
Июнь 01, 2017, 14:33 »
Тогда уж:
Код
C++ (Qt)
int
row
=
ui
->
tableView
->
currentIndex
(
)
.
row
(
)
;
model
->
removeRow
(
row
)
;
Записан
https://github.com/gil9red
https://ru.stackoverflow.com/users/201445/gil9red
diagnosefiz
Гость
Re: Добавление и удаление строк из TableView.
«
Ответ #9 :
Июнь 01, 2017, 14:35 »
Цитата: gil9red от Июнь 01, 2017, 14:33
Тогда уж:
Код
C++ (Qt)
int
row
=
ui
->
tableView
->
currentIndex
(
)
.
row
(
)
;
model
->
removeRow
(
row
)
;
Спасибо большое) получилось.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...