crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

 
Тема закрытаНачать новую тему
> [РЕШЕНО] QTableView + QSqlTableModel, Удаление данных, PyQt4
VBA
  опции профиля:
сообщение 13.1.2009, 18:15
Сообщение #1


Новичок


Группа: Новичок
Сообщений: 4
Регистрация: 13.1.2009
Пользователь №: 487

Спасибо сказали: 0 раз(а)




Репутация:   0  


Использую QSqlTableModel и QTableView в связке с PyQt4, для отображения данных из таблицы БД.

...
Model = QSqlTableModel(self)
Model.setTable("test")
Model.setEditStrategy(QSqlTableModel.OnManualSubmit)
Model.select()
...
TableView = QTableView(self)
TableView.setModel(Model)
...


Пытаюсь удалить строку, которую выбрал пользователь в TableView, таким образом:
Index = TableView.currentIndex()
TableView.model().removeRow(Index.row())
TableView.model().submitAll()


В результате получаю ошибку:
QSqlQuery::value: not positioned on a valid record

Причем, TableView.model().removeRow(Index.row()) возвращает True, а "затык" происходит на TableView.model().submitAll() (возвращает False).

ТableView.model().lastError().text() пишет следующее:
No data supplied for parameters in prepared statement QMYSQL3: Unable to execute statement

Добавление записей происходит без проблем, а вот удаление... (((

Сообщение отредактировал Litkevich Yuriy - 31.1.2009, 12:34
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 13.1.2009, 18:29
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


я так делал (C++):
// Удаляем строку
void TableEditor::SlotDel()
{
  int row;
  QItemSelectionModel    *selectModel;
  QModelIndexList         indexes;
  QModelIndex             index;
  
    // Узнаем выделенную строку
    selectModel = view->selectionModel();
    indexes = selectModel->selectedIndexes();
    
    foreach(index, indexes)
    {
        QString str;
        row = index.row();
        if (!model->removeRows(row,1))
        {
            str = model->lastError().text();
            qDebug() << str << "\n\r";
            break;
        }
        else
        {
            view->setRowHidden(row, true);
        }
    }
    SlotChange();
    SlotClick();
    
}
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
VBA
  опции профиля:
сообщение 13.1.2009, 18:50
Сообщение #3


Новичок


Группа: Новичок
Сообщений: 4
Регистрация: 13.1.2009
Пользователь №: 487

Спасибо сказали: 0 раз(а)




Репутация:   0  


Цитата(Litkevich Yuriy @ 13.1.2009, 17:29) *
я так делал (C++):
...

Так это получается удаляються только строки из QTableView, а из самой таблицы БД нет.
Мне надо, чтобы удалялись записи из самой БД, физически, если можно так назвать.
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 13.1.2009, 18:54
Сообщение #4


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(VBA @ 13.1.2009, 21:50) *
Так это получается удаляються только строки из QTableView, а из самой таблицы БД нет.
Мне надо, чтобы удалялись записи из самой БД, физически, если можно так назвать.
да в приведенном примере нет подтверждения действия так как у меня на это отдельная кнопочка. Но я пока вижу разницу только в методах:
у тебя removeRow(...), а уменя removeRows(...)
может быть в этом дело?

а подверждаю так:
void TableEditor::SlotSubmit()
{
    model->database().transaction();
    if (model->submitAll())
    {
        model->database().commit();
        model->select();
        // Опять применить и отмена не активны
        BtnDis();    
    }
    else
    {
        model->database().rollback();
        QMessageBox::critical(this, tr("Ошибка"),
                             tr("Сообщение БД:\r\n %1")
                             .arg(model->lastError().databaseText()));
    }
}
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
VBA
  опции профиля:
сообщение 13.1.2009, 19:16
Сообщение #5


Новичок


Группа: Новичок
Сообщений: 4
Регистрация: 13.1.2009
Пользователь №: 487

Спасибо сказали: 0 раз(а)




Репутация:   0  


Цитата(Litkevich Yuriy @ 13.1.2009, 17:54) *
Но я пока вижу разницу только в методах:
у тебя removeRow(...), а уменя removeRows(...)
может быть в этом дело?

Переделал твой код в "питоновский"... результат тот же, при вызове submitAll() получаю:
QSqlQuery::value: not positioned on a valid record
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 13.1.2009, 19:52
Сообщение #6


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Хм. Даже не знаю в чем может быть проблема, я проверял только с двумя БД SQLite и FireBird. А это не может быть багом именно PyQt? (что-то не до конца реализовано)
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
VBA
  опции профиля:
сообщение 14.1.2009, 0:21
Сообщение #7


Новичок


Группа: Новичок
Сообщений: 4
Регистрация: 13.1.2009
Пользователь №: 487

Спасибо сказали: 0 раз(а)




Репутация:   0  


Уф... заработало... :)

У меня в таблице БД первое поле - это ID записи. Соответственно, я его пытался не отображать в QTableView. Согласно офф. доке http://doc.trolltech.com/4.4/qsqltablemodel.html#details я написал:
Model.removeColumn(0)

Поле стало невидимым, но вылезли вот такие непонятные проблемы (кстати, до сих пор не пойму их суть).

Закоментировал эту строку и все чудом заработало.
Поле (а точнее уже столбец) скрываю не в модели, а в вьювере:
TableView.setColumnHidden(0, True)
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
Litkevich Yuriy
  опции профиля:
сообщение 14.1.2009, 5:56
Сообщение #8


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(VBA @ 14.1.2009, 3:21) *
Поле (а точнее уже столбец) скрываю не в модели, а в вьювере:
угу, сюда еще глянь
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Тема закрытаНачать новую тему
Теги


2 чел. читают эту тему (гостей: 2, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 11.12.2024, 16:17